(1)多线程-线程的创建

继承Thread

通过继承Thread类来创建并启动多线程的一般步骤:

  • 定义Thread类的子类,并重写该类的run()方法,该方法的方法体就是线程需要完成的任务,run()方法也成为线程执行体。
  • 创建Thread子类的实例,也就是创建了线程对象
  • 启动线程,即调用线程的start()方法
public class MyThread extends Thread {

    @Override
    public void run() {
        System.out.println("使用继承Thread方式创建线程");
    }
}
public class TestThread {

    public static void main(String[] args) {
        System.out.println("JVM 启动 main 线程,main 线程执行 main 方法");
        MyThread thread = new MyThread();
        thread.start();
        /**
         * 调用线程的 start()方法来启动线程, 启动线程的实质就是请求 JVM 运行相应的 线程,这个线程具体在什么时候运行由线程调度器(Scheduler)决定
         * 注意:
         * start()方法调用结束并不意味着子线程开始运行
         * 新开启的线程会执行 run()方法
         * 如果开启了多个线程,start()调用的顺序并不一定就是线程启动的顺序
         * 多线程运行结果与代码执行顺序或调用顺序无关
         */
        System.out.println("main 线程后面其他 的代码...");
    }
}

实现Runnable接口创建线程

通过实现Runnable接口创建并启动线程一般步骤如下:

  • 定义Runnable接口的实现类,一样要重写run()方法,这个run()方法和Thread中的run()方法一样是线程的执行体
  • 创建Runnable实现类的实例,并用这个实例作为Thread的target来创建Thread对象,这个Thread对象才是真正的线程对象
  • 第三部依然是通过调用线程对象的start()方法来启动线程
public class MyRunnable implements Runnable {

    @Override
    public void run() {
        System.out.println("使用实现Runnable接口方式创建线程");
    }
}
public class TestThread {

    public static void main(String[] args) {
        System.out.println("JVM 启动 main 线程,main 线程执行 main 方法");
        MyRunnable runnable = new MyRunnable();
        Thread thread = new Thread(runnable);
        thread.start();
    }
}

实现Callable和Future接口创建线程

和Runnable接口不一样,Callable接口提供了一个call()方法作为线程执行体,call()方法比run()方法功能要强大。call()方法可以有返回值call()方法可以声明抛出异常Java5提供了Future接口来代表Callable接口里call()方法的返回值,并且为Future接口提供了一个实现类FutureTask,这个实现类既实现了Future接口,还实现了Runnable接口,因此可以作为Thread类的target。在Future接口里定义了几个公共方法来控制它关联的Callable任务。

  • 创建Callable接口的实现类,并实现call()方法,然后创建该实现类的实例(从java8开始可以直接使用Lambda表达式创建Callable对象)。
  • 使用FutureTask类来包装Callable对象,该FutureTask对象封装了Callable对象的call()方法的返回值
  • 使用FutureTask对象作为Thread对象的target创建并启动线程(因为FutureTask实现了Runnable接口)
  • 调用FutureTask对象的get()方法来获得子线程执行结束后的返回值
public class MyCallable implements Callable {
    @Override
    public Object call() throws Exception {
        System.out.println("使用实现Callable接口方式创建线程");
        return 10;
    }
}
public class TestThread {

    public static void main(String[] args) {
        System.out.println("JVM 启动 main 线程,main 线程执行 main 方法");
        MyCallable callable = new MyCallable();
        FutureTask futureTask = new FutureTask<>(callable);
        new Thread(futureTask).start();
        try {
            System.out.println(futureTask.get());
        } catch (InterruptedException e) {
            e.printStackTrace();
        } catch (ExecutionException e) {
            e.printStackTrace();
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值