Java虚拟线程是JDK 21引入的轻量级协程,由JVM调度、栈仅约2KB、支持海量并发;平台线程则一对一映射OS线程、栈默认1MB、资源受限。
Java虚拟线程(Virtual Thread)是JDK 21正式引入的轻量级线程实现,本质是用户态调度的协程,由JVM管理;而平台线程(Platform Thread)就是我们熟悉的传统Java线程,直接一对一映射到操作系统线程(OS thread),受系统资源限制更严格。
虚拟线程由JVM在少量平台线程上协作式调度,一个平台线程可承载成千上万个虚拟线程;平台线程则由操作系统内核直接调度,每个线程都占用独立的内核栈(通常1MB左右),创建成本高、数量受限。
虚拟线程栈空间默认仅约2KB(可动态增长),且按需分配;平台线程栈固定较大(Linux默认1MB),大量线程易引发OOM或线程创建失败。
虚拟线程仍继承Thread类,支持start()、join()等方法,代码写法几乎不变;但其生命周期、监控方式和调试体验与平台线程不同。
Thread.stop()、Thread.suspend()等已废弃/禁用方法(运行时抛UnsupportedOperationException)Thread.currentThread().isVirtual()可判断当前
是否运行在虚拟线程VirtualThread[#n]而非Thread[#n]
虚拟线程适合高并发I/O密集型服务(如Web API、数据库连接池封装、消息监听);平台线程更适合CPU密集型任务、需要精确线程控制(如实时调度、JNI回调)、或依赖线程局部状态(ThreadLocal需谨慎——虚拟线程中频繁创建销毁会导致TL泄漏风险)。
Thread.ofVirtual().unstarted(Runnable)或Executors.newVirtualThreadPerTaskExecutor()启动ForkJoinPool或专用平台线程池)ThreadLocal:建议改用ScopedValue(JDK 20+)替代,或确保清理逻辑可靠