博客
关于我
Java--多线程(1)Thread
阅读量:338 次
发布时间:2019-03-01

本文共 1012 字,大约阅读时间需要 3 分钟。

多线程的创建一:继承于Thread类

创建多线程的常用方法之一是通过继承Thread类来实现。在Java中,Thread类是实现多线程的基础类,任何继承于Thread类的子类都可以作为一个线程对象。以下是创建这样的线程的具体步骤:

  • 创建一个继承于Thread类的子类
  • 重写Thread类的run()方法,定义线程的执行逻辑
  • 创建Thread类的子类对象
  • 通过此类对象调用start()方法
  • Thread类提供了一些常用的方法来管理线程:

    • start():启动线程,并执行run()方法
    • getName():获取线程的名称
    • setName():设置线程的名称
    • currentThread():返回当前线程(在Thread子类中,为this)
    • yield():让线程让步
    • join():等待线程的完成
    • sleep():线程休眠

    需要注意的是,一个继承于Thread的子类对象只能调用一次start()方法。例如:

    public class TestThread {    public static void main(String[] args) {        MyThread mt = new MyThread();        mt.start();        for (int i = 0; i < 100; i++) {            System.out.println("多线程0");        }    }}class MyThread extends Thread {    @Override    public void run() {        for (int i = 0; i < 100; i++) {            System.out.println("多线程1");        }    }}

    如果需要更灵活地使用run方法,可以考虑使用匿名子类的形式:

    new MyThread() {    @Override    public void run() {        for (int i = 0; i < 100; i++) {            System.out.println("多线程1");        }    }}.start();

    在实际应用中,匿名子类的方式更为常用,因为它可以避免定义一个独立的类,简化代码结构。

    转载地址:http://uoca.baihongyu.com/

    你可能感兴趣的文章
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty源码—8.编解码原理二
    查看>>
    Netty源码解读
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty相关
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>
    NetworkX系列教程(11)-graph和其他数据格式转换
    查看>>
    Networkx读取军械调查-ITN综合传输网络?/读取GML文件
    查看>>
    Net与Flex入门
    查看>>
    net包之IPConn
    查看>>
    NFinal学习笔记 02—NFinalBuild
    查看>>
    NFS共享文件系统搭建
    查看>>