Java虚拟线程是JDK21正式引入的轻量级线程,通过Thread.ofVirtual()或Executors.newVirtualThreadPerTaskExecutor()创建,适用于高并发场景,但需避免阻塞操作和CPU密集计算。
Java 虚拟线程(Virtual Thread)是 JDK 21 正式引入的轻量级线程实现,基于 Project Loom,用于大幅提升高并发场景下的吞吐能力。它不是通过 new Thread() 创建的传统平台线程,而是由 JVM 管理、在用户态调度的“纤程”,开销极小,可轻松创建百万级实例。
Thread.ofVirtual() 创建并启动这是最推荐、最直观的方式,返回一个 Thread.Builder,支持链式配置和立即启动:
Thread.ofVirtual().unstarted(Runnable) 获取未启动的虚拟线程对象,再手动调用 start()
Thread.ofVirtual().start(Runnable) 一步创建并启动示例:
Thread vt = Thread.ofVirtual().name("my-vt").start(() -> {
System.out.println("运行在虚拟线程: " + Th
read.currentThread());
});Executors.newVirtualThreadPerTaskExecutor()
适合任务驱动型场景(如 Web 请求、异步 I/O),每次提交任务都自动分配一个新虚拟线程,无需手动管理生命周期:
ExecutorService 是“按需创建 + 自动回收”的,任务结束即释放资源示例:
try (ExecutorService executor = Executors.newVirtualThreadPerTaskExecutor()) {
executor.submit(() -> System.out.println("任务执行中"));
}虚拟线程不是“万能替代品”,使用时需注意:
Thread.sleep()、Object.wait()、阻塞 I/O(如 FileInputStream.read())等会挂起平台线程的操作——应改用 java.util.concurrent.StructuredTaskScope 或非阻塞 API(如 NIO、HttpClient 异步模式)-XX:+UnlockDiagnosticVMOptions -XX:+DebugNonSafepoints 等参数辅助观测虚拟线程是 JDK 21+ 的标准特性,但需满足:
--enable-preview)--source 21 --target 21)