登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
资讯
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
返回列表
首页
›
业界区
›
安全
›
Java虚拟线程实战:Project Loom让并发编程更简单 ...
Java虚拟线程实战:Project Loom让并发编程更简单
[ 复制链接 ]
狭踝仇
3 天前
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
前言
Java 21 正式引入虚拟线程(Virtual Threads),这是 Project Loom 的核心成果。虚拟线程让 Java 并发编程从"难"变"简",彻底改变了高并发应用的开发方式。本文带你全面掌握虚拟线程。
一、虚拟线程 vs 平台线程
平台线程
:对应操作系统线程,创建成本高(约1MB栈内存),数量受限
虚拟线程
:JVM 管理的轻量级线程,创建成本极低(约几KB),可创建数百万个
// 平台线程:创建100万个会OOM
Thread platformThread = new Thread(() -> doWork());
platformThread.start();
// 虚拟线程:创建100万个轻松搞定
Thread virtualThread = Thread.ofVirtual().start(() -> doWork());
复制代码
二、创建虚拟线程的四种方式
// 方式1:Thread.ofVirtual()
Thread vt1 = Thread.ofVirtual().name("vt-1").start(() -> {
System.out.println("Virtual thread: " + Thread.currentThread());
});
// 方式2:Thread.startVirtualThread()
Thread vt2 = Thread.startVirtualThread(() -> {
System.out.println("Running in virtual thread");
});
// 方式3:虚拟线程 ExecutorService
try (ExecutorService executor = Executors.newVirtualThreadPerTaskExecutor()) {
executor.submit(() -> processRequest());
executor.submit(() -> processRequest());
}
// 方式4:ThreadFactory
ThreadFactory factory = Thread.ofVirtual().factory();
Thread vt4 = factory.newThread(() -> doWork());
vt4.start();
复制代码
三、实战:高并发 HTTP 请求处理
// 传统方式:线程池,受限于线程数
ExecutorService threadPool = Executors.newFixedThreadPool(200);
// 虚拟线程方式:每个请求一个虚拟线程
@RestController
public class UserController {
@GetMapping("/users/{id}")
public User getUser(@PathVariable Long id) {
// 虚拟线程会在 I/O 阻塞时自动挂起,释放载体线程
return userService.findById(id); // 数据库查询
}
}
// Spring Boot 3.2+ 开启虚拟线程
// application.yml
// spring:
// threads:
// virtual:
// enabled: true
复制代码
四、性能对比测试
public class PerformanceTest {
// 模拟 I/O 密集型任务
static void ioTask() throws InterruptedException {
Thread.sleep(100); // 模拟数据库查询
}
public static void main(String[] args) throws Exception {
int taskCount = 10_000;
// 平台线程池
long start1 = System.currentTimeMillis();
try (ExecutorService pool = Executors.newFixedThreadPool(200)) {
List<Future<?>> futures = new ArrayList<>();
for (int i = 0; i < taskCount; i++) {
futures.add(pool.submit(() -> { ioTask(); return null; }));
}
for (Future<?> f : futures) f.get();
}
System.out.println("Platform threads: " + (System.currentTimeMillis() - start1) + "ms");
// 输出约:5200ms
// 虚拟线程
long start2 = System.currentTimeMillis();
try (ExecutorService vExecutor = Executors.newVirtualThreadPerTaskExecutor()) {
List<Future<?>> futures = new ArrayList<>();
for (int i = 0; i < taskCount; i++) {
futures.add(vExecutor.submit(() -> { ioTask(); return null; }));
}
for (Future<?> f : futures) f.get();
}
System.out.println("Virtual threads: " + (System.currentTimeMillis() - start2) + "ms");
// 输出约:120ms,提升40倍!
}
}
复制代码
五、注意事项
避免 synchronized 块
:会导致虚拟线程固定(pinning),改用 ReentrantLock
不适合 CPU 密集型任务
:虚拟线程优势在 I/O 密集型场景
ThreadLocal 谨慎使用
:大量虚拟线程时内存占用可能增加
// 错误:synchronized 导致 pinning
synchronized (lock) {
Thread.sleep(100); // 虚拟线程被固定,无法挂起
}
// 正确:使用 ReentrantLock
ReentrantLock lock = new ReentrantLock();
lock.lock();
try {
Thread.sleep(100); // 虚拟线程可以正常挂起
} finally {
lock.unlock();
}
复制代码
总结
虚拟线程是 Java 并发编程的重大突破,特别适合 I/O 密集型的微服务场景。升级到 Java 21 + Spring Boot 3.2,一行配置即可享受虚拟线程带来的性能提升。
觉得有帮助请点赞收藏!有问题欢迎评论区交流
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
Java
虚拟
线程
实战
Project
相关帖子
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
MyBatis-Plus实战:Spring Boot数据库操作效率提升10倍
Spring Cloud Gateway实战:微服务API网关从零到一
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
业界
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
0
42
吁寂
2026-04-05
业界
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
0
87
魄柜
2026-04-05
业界
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
1
721
梢疠
2026-04-05
业界
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
0
986
嗣伐
2026-04-05
业界
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
0
250
院儿饯
2026-04-05
业界
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
2
917
左丘平莹
2026-04-05
业界
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
0
676
格恳绌
2026-04-05
业界
开发实战:asp.net core + ef core 实现动态可扩展的分页方案
1
237
终秀敏
2026-04-05
安全
MyBatis-Plus实战:Spring Boot数据库操作效率提升10倍
0
901
副我
2026-04-06
安全
Spring Cloud Gateway实战:微服务API网关从零到一
0
193
后沛若
2026-04-06
路逸思
昨天 21:42
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
前排留名,哈哈哈
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
代码
科技
签约作者
程序园优秀签约作者
发帖
狭踝仇
昨天 21:42
关注
0
粉丝关注
24
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
3934307807
991126
anyue1937
9994892
kk14977
6845359
4
xiangqian
638210
5
神泱
9516
6
韶又彤
9910
7
荪俗
8994
8
宋子
9875
9
蓬森莉
9869
10
俞瑛瑶
10000
查看更多
今日好文热榜
1
【小记】解决校园网中单播互通的不同子网间
1
【小记】解决校园网中单播互通的不同子网间
349
【节点】[Posterize节点]原理解析与实际应
1
【小记】解决校园网中单播互通的不同子网间
1
【小记】解决校园网中单播互通的不同子网间
1
【小记】解决校园网中单播互通的不同子网间
1
【小记】解决校园网中单播互通的不同子网间
1
【小记】解决校园网中单播互通的不同子网间
1
【小记】解决校园网中单播互通的不同子网间
1
【小记】解决校园网中单播互通的不同子网间
754
GitHub 热门项目 Top 10 | 2026 年 04 月 0
191
Spring Cloud Gateway实战:微服务API网关
783
罗兰艺境GEO内容工程实战复盘:CSDN 92分技
523
MacBook Air 本地运行大语言模型(LLM)
49
【渗透测试】玄机&Maze 全过程wp
792
AI元人文:大儒家观之功夫论——痕迹生生、
274
"Meta-Harness: End-to-End Optimization o
398
UI 自动化测试产品深度对比分析报告
237
指派问题WebApp实验室:从建模到智能分配的
901
MyBatis-Plus实战:Spring Boot数据库操作