0

0

Java虚拟线程与平台线程区别_Java虚拟线程和传统线程有什么不同

舞姬之光

舞姬之光

发布时间:2025-12-22 11:03:45

|

431人浏览过

|

来源于php中文网

原创

java虚拟线程是jdk 21引入的轻量级协程,由jvm调度、栈仅约2kb、支持海量并发;平台线程则一对一映射os线程、栈默认1mb、资源受限。

java虚拟线程与平台线程区别_java虚拟线程和传统线程有什么不同 - php中文网

Java虚拟线程(Virtual Thread)是JDK 21正式引入的轻量级线程实现,本质是用户态调度的协程,由JVM管理;而平台线程(Platform Thread)就是我们熟悉的传统Java线程,直接一对一映射到操作系统线程(OS thread),受系统资源限制更严格。

调度方式不同

虚拟线程由JVM在少量平台线程上协作式调度,一个平台线程可承载成千上万个虚拟线程;平台线程则由操作系统内核直接调度,每个线程都占用独立的内核(通常1MB左右),创建成本高、数量受限。

  • 虚拟线程默认使用ForkJoinPool.commonPool()或自定义的Carrier Thread Pool作为载体执行任务
  • 平台线程一旦启动,就绑定到某个OS线程,阻塞时整个OS线程挂起,无法复用
  • 虚拟线程遇到I/O、sleep、synchronized等阻塞操作时,会自动让出载体线程,不造成浪费

内存与资源开销差异大

虚拟线程栈空间默认仅约2KB(可动态增长),且按需分配;平台线程栈固定较大(Linux默认1MB),大量线程易引发OOM或线程创建失败。

迅易鲜花网店管理系统
迅易鲜花网店管理系统

功能模块:功能完善、展示信息丰富的电子商店销售平台;针对企业与个人的网上销售系统;开放式远程商店管理;完善的订单管理 ; 快速建店:只需简单设置,10分钟即可以建立一个功能完备的网上商城; 操作简便:采用人性化的布局,界面规范,操作简捷; 安装方便:只需传到您的虚拟空间即可; HTML编辑器:内置优秀的HTML在线编辑器; 可扩展性:软件构架灵活,考虑未来功能扩充之需要,具有较强的可扩展性; 完善

下载
  • 启动10万个虚拟线程通常只需几MB堆外内存
  • 同样数量的平台线程几乎必然失败:Linux默认每进程线程数上限常为几千,且内存迅速耗尽
  • 虚拟线程对象本身存在于Java堆中,GC可回收;平台线程对象虽也GC,但底层OS资源释放有延迟

编程模型保持兼容,但行为逻辑变了

虚拟线程仍继承Thread类,支持start()join()等方法,代码写法几乎不变;但其生命周期、监控方式和调试体验与平台线程不同。

立即学习Java免费学习笔记(深入)”;

  • 不能对虚拟线程调用Thread.stop()Thread.suspend()等已废弃/禁用方法(运行时抛UnsupportedOperationException
  • Thread.currentThread().isVirtual()可判断当前是否运行在虚拟线程
  • JFR(Java Flight Recorder)和JMX支持虚拟线程监控,但线程dump中显示为VirtualThread[#n]而非Thread[#n]

适用场景明显分化

虚拟线程适合高并发I/O密集型服务(如Web API、数据库连接池封装、消息监听);平台线程更适合CPU密集型任务、需要精确线程控制(如实时调度、JNI回调)、或依赖线程局部状态(ThreadLocal需谨慎——虚拟线程中频繁创建销毁会导致TL泄漏风险)。

  • 推荐用Thread.ofVirtual().unstarted(Runnable)Executors.newVirtualThreadPerTaskExecutor()启动
  • 避免在虚拟线程中长时间执行纯计算(应交由ForkJoinPool或专用平台线程池)
  • 慎用ThreadLocal:建议改用ScopedValue(JDK 20+)替代,或确保清理逻辑可靠

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

442

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

442

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

764

2023.08.10

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

99

2025.12.01

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

384

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2110

2023.08.14

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.4万人学习

Git 教程
Git 教程

共21课时 | 4.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号