news 2026/4/18 3:52:36

JDK21-虚拟线程(原理)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JDK21-虚拟线程(原理)

一、先给结论

虚拟线程不是不运行在 OS 线程上,而是:
只在“真正需要 CPU 时”才短暂占用 OS 线程。
在 IO 等待时,JVM 会把它“卸载”下来。


二、为什么传统线程一定占用 OS 线程?

1️⃣ Java 线程 = OS 线程(1:1)

在 Java 21 之前:

JavaThread<==>OSThread

当你写:

Threadt=newThread(()->httpCall());t.start();

本质是:

  • JVM 调用pthread_create
  • 创建一个真实的内核线程
  • 栈、调度、阻塞全交给操作系统

2️⃣ OS 不懂“这是 IO 等待”

当线程调用:

socket.read();

操作系统只知道一件事:

“这个线程现在在等数据”

于是:

  • OS 把线程状态设为BLOCKED
  • 线程仍然存在
  • 仍然占:
    • 内核线程结构
    • 栈内存
    • 调度成本

📌OS 无法把这个线程“拆掉”再给别人用


三、虚拟线程是如何“骗过”操作系统的?

关键思想:

👉阻塞不交给 OS,而是交给 JVM


1️⃣ 虚拟线程的真实结构

Virtual Thread(JVM对象) | |--- Continuation(可挂起的执行体) | |--- 运行在 ↓ Carrier Thread(少量 OS 线程)

Carrier Thread 才是真正的 OS 线程


2️⃣ JVM 在关键 IO 点“插手”了

虚拟线程的核心魔法在这里👇

传统线程:

Thread | |-- socket.read() | |-- OS 阻塞线程

虚拟线程:

VirtualThread | |-- socket.read() | |-- JVM 拦截 | |-- 保存当前执行现场(Continuation) |-- 从 Carrier Thread 上卸载 |-- 把 Carrier Thread 还给调度器

📌OS 完全不知道有这么回事


3️⃣ JVM 怎么知道“这是 IO”?

因为:

👉 JDK 的 IO 被“改造”了(关键)

以下 API 在虚拟线程下是可挂起的

  • Socket
  • HttpClient
  • InputStream / OutputStream
  • Selector
  • NIO

JDK 内部逻辑(简化):

if(currentThread.isVirtual()){parkContinuation();}else{blockOSThread();}

四、Continuation:真正的“黑科技”

1️⃣ 什么是 Continuation?

你可以理解为:

一个可以暂停 / 恢复的调用栈快照

它保存了:

  • 当前方法栈
  • 局部变量
  • 执行位置

2️⃣ 挂起时发生了什么?

┌──────────────┐ │ 方法 A │ │ 方法 B │ │ 方法 C <-- 当前执行点 └──────────────┘

JVM 做了:

  1. 把这段执行栈复制到堆内存
  2. 解绑当前 OS 线程
  3. 标记为 WAITING

3️⃣ 恢复时发生了什么?

当 IO 就绪:

  1. JVM 选一个空闲 Carrier Thread
  2. 把 Continuation 装回去
  3. 从 C 方法继续执行

👉就像什么都没发生过


五、为什么说“虚拟线程不占用 OS 线程”?

更准确的说法是:

**虚拟线程在“运行时”才占用 OS 线程
**在“等待时”不占用 OS 线程

对比:

状态传统线程虚拟线程
执行 CPU占 OS 线程占 OS 线程
等 IO仍占 OS 线程❌ 不占
空闲不占

六、这就是为什么并发能暴涨 100 倍

假设:

  • OS 线程池:200
  • IO 等待时间:95%

传统模型:

200 个线程 ≈ 190 个在等 IO ≈ 10 个在干活

虚拟线程模型:

200 个 Carrier Thread + 100,000 个 Virtual Thread ≈ 99,500 个在挂起 ≈ 500 个随时可运行

七、为什么你“几乎不用改代码”?

因为:

  • 同步 API 没变
  • try/catch 没变
  • ThreadLocal 可用
  • JDBC / HTTPClient 可用

JVM在你看不到的地方做了调度革命。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/24 9:26:14

JDK21-虚拟线程(实战)

背景&#xff1a; 系统需要在极短的时间(短时间可以减少实际余额偏差)拉取多个第三方平台的账户余额&#xff0c;并保存到数据库。 每个平台都是 HTTP IO 调用 数据解析 DB 写入&#xff0c;典型的 IO 密集型任务。 一、业务场景简介(将具体的平台脱敏了,是真实数据) 系统涉…

作者头像 李华
网站建设 2026/4/18 0:52:03

AI Agent‘翻车‘别慌!Skills来救场,小白也能当大神!

最近一段时间&#xff0c;如果你关注 Agent 相关的产品和讨论&#xff0c;大概率会注意到一个变化&#xff1a;多款主流工具/平台都相继发布了对 Skills 的支持。 比如&#xff1a;Cursor 的 beta 版里已经开始支持 Skills&#xff0c;Coze 这两天也刚发布了对 Skills 的支持&…

作者头像 李华
网站建设 2026/4/11 7:28:21

最新9大AI论文查重软件榜单,附赠专业改写技巧与避坑指南。

核心工具对比速览 工具名称 核心功能 处理时间 适配检测平台 特色优势 aibiye 降AIGC查重 20分钟 知网/格子达/维普 保留学术术语的AI痕迹弱化 aicheck AIGC检测降重 即时 主流学术平台 实时检测反馈精准降重 askpaper 学术AI优化 15-30分钟 高校常用系统 专…

作者头像 李华
网站建设 2026/3/27 23:52:32

【大数据毕设全套源码+文档】基于Python的农业大数据管理系统的设计与实现(丰富项目+远程调试+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/18 2:06:27

YOLOv13 性能核弹级升级!DCMB 模块实测,mAP 最高暴涨 13.88%

效果炸裂,绿色线条为添加DCMB模块,蓝色为原模型。 map提升9.23个点,map50 文章目录 移植 创建 ultralytics\cfg\models\v13\yolov13-DCMB.yaml 修改ultralytics\nn\tasks.py 修改ultralytics/nn/modules/__init__.py 修改ultralytics\nn\modules\block.py DCMB (Dynamic Con…

作者头像 李华
网站建设 2026/4/18 2:05:06

探索 iPiQ 谐波分析法在电力系统仿真中的奇妙旅程

ipiq谐波分析法电力系统仿真 在电力系统这个复杂的领域里&#xff0c;谐波问题就像是隐藏在暗处的小怪兽&#xff0c;时不时给系统的稳定运行带来麻烦。而 iPiQ 谐波分析法宛如一把犀利的宝剑&#xff0c;能有效应对这些谐波挑战。今天&#xff0c;咱就来深入聊聊 iPiQ 谐波分…

作者头像 李华