【JavaEE】—— 创建线程的三种方式(Thread、Runnable、Callable)

目录

一、继承Thread类(不推荐使用)

具体操作:

注意事项

二、实现Runnable接口(常用)

具体操作:

三、实现Callable接口(常用)

具体操作:


一、继承Thread类(不推荐使用)

继承Thread类,重写Run方法

具体操作:

  1. 定义一个子类MyThread继承线程类Thread,重写run()方法
  2. 创建MyThread类对象
  3. 调用线程对象的start()方法启动线程
java 复制代码
public class Test {
    public static void main(String[] args) {
        MyThread t = new MyThread();
        t.start();
    }
}

class MyThread extends Thread {
    public void run() {
        System.out.println(Thread.currentThread().getName());
    }
}

**优点:**编程简单

**缺点:**1、耦合度高,线程任务与线程对象绑定,一个线程任务只能由一个线程对象执行。

2、由于Java单继承特性,只能继承一个类,不能再继承其他类。

注意事项

1、启动线程调用的是start方法,而不是run方法

直接调用run方法会当成普通方法执行,相当于还是单线程

2、不要把主线程任务放在启动子线程之前

这样主线程会先结束,相当于单线程的效果

二、实现Runnable接口(常用)

实现Runnable接口,重写run()方法

具体操作:

  1. 定义一个线程任务类MyRunnable,实现Runnable接口,重写run()方法
  2. 创建MyRunnable任务对象
  3. 把MyRunnable任务对象交给Thread处理
java 复制代码
public class Test2 {
    public static void main(String[] args) {
        //方式一
        MyRunnable runnable = new MyRunnable();
        Thread thread = new Thread(runnable);
        thread.start();
        //方式二:简化使用
        new Thread(new Runnable() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName());
            }
        }).start();
    }
}
class MyRunnable implements Runnable {
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName());
    }
}

**优点:**1、相同的任务可以由不同的线程执行,代码复用性提高。

2、更灵活,可以继承其他类

**缺点:**相比与继承Thread类,需要多创建Runnable线程任务对象

三、实现Callable接口(常用)

前两种创建方式都存在一个问题:不能返回执行结果!

具体操作:

  1. 定义一个类MyCallable实现Callable接口,重写call方法
  2. 创建MyCallable对象,封装成FutureTask
  3. 把线程任务对象交给Thread对象,调用start方法启动
  4. 线程执行完毕后,通过FutureTask对象的get方法获取执行结果
java 复制代码
public class Test3 {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        //方式一
        MyCallable callable = new MyCallable();
        FutureTask<String> futureTask = new FutureTask<>(callable);
        Thread thread = new Thread(futureTask);
        thread.start();
        System.out.println(futureTask.get());
    }
}
class MyCallable implements Callable {
    @Override
    public Object call() throws Exception {
        return Thread.currentThread().getName();
    }
}
相关推荐
fouryears_234172 小时前
Flutter InheritedWidget 详解:从生命周期到数据流动的完整解析
开发语言·flutter·客户端·dart
我好喜欢你~2 小时前
C#---StopWatch类
开发语言·c#
桦说编程3 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen3 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研3 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
没有bug.的程序员4 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
甄超锋5 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
cui__OaO5 小时前
Linux软件编程--线程
linux·开发语言·线程·互斥锁·死锁·信号量·嵌入式学习
阿华的代码王国5 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
Zyy~5 小时前
《设计模式》装饰模式
java·设计模式