我该如何创建一个Java线程?

在JDK8中,不使用线程池的情况下,一般使用Thread类来创建线程,使用Thread类有三种方式来创建线程。

继承Thread类:通过该方式需要集成hread类,Java是单继承的,这种方式会占用继承名额,不够灵活。

实现Runnable接口:该方法没有返回值,可以通过引用变量的方式返回线程中的计算结果

实现Callable接口:该方法可以返回值,不过需要使用FutureTask对Callable实现类再封装一层,Callable实现类不能直接作为Thread构造方法的参数(代码中通过FutureTask.get()方法获取返回结果,这是一个异步阻塞方法,其方法内部有一个for死循环,直到执行任务的线程修改了FutureTask的state,这个这里不再细述)。

下面是示例代码:

java 复制代码
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;

// 通过实现Runnable接口来创建线程
class Worker01Thread implements Runnable{

    @Override
    public void run() {
        System.out.println("worker01 start work");
    }

}


// 通过继承Thread类来创建线程,其实和Runnable接口挺像的
class Worker02Thread extends Thread{
    @Override
    public void run() {
        System.out.println("worker02 start work");
    }
}

// 通过实现Callable接口来创建线程,其call()方法是有返回值的
class Worker03Thread implements Callable<String>{
    @Override
    public String call() throws Exception {
        return "worker03 start work";
    }
}

public class CreateThreadDemo01 {

    public static void main(String[] args) throws ExecutionException, InterruptedException {

        Thread t1 = new Thread(new Worker01Thread());
        t1.start();

        Thread t2 = new Thread(new Worker02Thread());
        t2.start();

        // 这里需要将Callable接口的实现类封装成FutureTask,再创建线程
        FutureTask<String> futureTask = new FutureTask<>(new Worker03Thread());
        Thread t3 = new Thread(futureTask);
        t3.start();
        // futureTask.get(),可以获取线程的返回值,如果线程被阻塞住,futureTask.get()方法也会一直阻塞在这里
        System.out.println(futureTask.get());

    }
}

在JDK21中,可以创建虚拟线程,虚拟线程只能通过Runnable接口或者线程池的方式创建,下面是Runnable接口创建虚拟线程的示例:

java 复制代码
class VirtualWorkerThread implements Runnable {
    @Override
    public void run() {
        System.out.println("VirtualWorkerThread start work");
    }
}

public class CreateVirtualThreadDemo01 {
    public static void main(String[] args) throws InterruptedException {
        Thread t1 = Thread.ofVirtual().start(new VirtualWorkerThread());
        t1.join(); // 不加这一步,主线程提前结束,虚拟线程还没输出结果
    }
}
相关推荐
Java面试题总结6 小时前
java高频面试题(2026最新)
java·开发语言·jvm·数据库·spring·缓存
苦逼的猿宝6 小时前
学生心理咨询评估系统
java·毕业设计·springboot·计算机毕业设计
隔窗听雨眠6 小时前
doctype、charset、meta如何控制整个渲染流水线
java·服务器·前端
西安邮电大学8 小时前
SpringBean完整生命周期
java·spring
刀法如飞8 小时前
DDD 与 Ontology 对比分析:哪一种更适合AI时代复杂系统构建?
java·架构·领域驱动设计
SunnyDays10118 小时前
Java 读写 Excel 公式:从基础到高级的实战总结
java·开发语言·excel
wb043072018 小时前
Java 26
java·开发语言
白露与泡影8 小时前
JVM GC调优实战:从线上频繁Full GC到RT降低80%的全过程
java·开发语言·jvm
范什么特西8 小时前
Spring 动态代理 静态代理
java·后端·spring
醇氧8 小时前
Spring 动态注册 Bean 深度解析:从源码到实践
java·后端·spring