虚拟线程是 Java 21 引入的一个新特性,用于简化并发编程。它与传统的操作系统线程相比,具有显著的优势:
创建虚拟线程非常简单。你可以像创建传统线程一样启动虚拟线程,但它的创建与启动更加轻量:
Thread virtualThread = Thread.ofVirtual().start(() -> {
System.out.println('虚拟线程正在运行');
});
System.out.println('主线程正在运行');
虚拟线程的延迟启动:
Thread virtualThread = Thread.ofVirtual()
.name('虚拟线程')
.unstarted(() -> System.out.println('虚拟线程运行中'));
virtualThread.start();
virtualThread.join(); // 等待虚拟线程完成
在 Spring Boot 项目中使用虚拟线程需要一些简单的配置:
pom.xml
中启用 --enable-preview
,以便支持虚拟线程特性。<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>21</source>
<target>21</target>
<compilerArgs>
<arg>--enable-preview</arg>
</compilerArgs>
</configuration>
</plugin>
application.properties
中启用性能监控工具:management.endpoints.web.exposure.include=health,info,metrics
@Bean
public TomcatProtocolHandlerCustomizer<?> protocolHandlerVirtualThreadExecutorCustomizer() {
return protocolHandler -> protocolHandler.setExecutor(Executors.newVirtualThreadPerTaskExecutor());
}
传统线程:
for (int i = 0; i < 100_000; i++) {
Thread thread = new Thread(() -> System.out.println(i));
thread.start();
thread.join();
}
执行耗时约 18.6 秒。
虚拟线程:
for (int i = 0; i < 100_000; i++) {
Thread thread = Thread.ofVirtual().unstarted(() -> System.out.println(i));
thread.start();
thread.join();
}
执行耗时仅 3.7 秒,性能提升了近 500% 。
在高并发场景下,虚拟线程的优势尤为明显。我们对比了传统线程与虚拟线程在处理 HTTP 请求时的表现。
配置 HTTP 线程执行器:
@Bean
public TomcatProtocolHandlerCustomizer<?> protocolHandlerVirtualThreadExecutorCustomizer() {
return protocolHandler -> protocolHandler.setExecutor(Executors.newVirtualThreadPerTaskExecutor());
}
请求测试:发送 1600 个 HTTP 请求,400 并发。
虚拟线程的吞吐量大幅提升,响应时间显著缩短。
除了虚拟线程,Java 还有一些其他的性能提升技巧,尤其适用于 Spring Boot 高并发场景:
parallelStream()
)来利用多核 CPU,提高处理速度。List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
numbers.parallelStream().forEach(number -> {
System.out.println(number * 2);
});
CompletableFuture
进行异步处理,减少线程阻塞,提高响应性能。CompletableFuture<Void> future = CompletableFuture.runAsync(() -> {
// 异步执行任务
System.out.println('异步任务完成');
});
future.join(); // 等待任务完成
Apache Commons Pool
)来管理资源,减少频繁的对象创建和销毁,提高内存使用效率。通过这些技巧,Spring Boot 应用能够在高并发场景下表现出更强的性能和更低的响应延迟。
最后欢迎加入苏三的星球,你将获得:商城系统实战、秒杀系统实战、代码生成工具、系统设计、性能优化、技术选型、高频面试题、底层原理、Spring源码解读、工作经验分享、痛点问题等多个优质专栏。
还有1V1答疑、修改简历、职业规划、送书活动、技术交流。
目前星球已经更新了4500+篇优质内容,还在持续爆肝中.....
星球已经被官方推荐了3次,收到了小伙伴们的一致好评。戳我加入学习,已有1500+小伙伴加入学习。
此外,推荐一下我的技术专栏《程序员最常见的100个问题》,目前已经更新了80多篇干货文章,里面收录了很多踩坑经历,对你的职业生涯或许有些帮助,最近收到的好评挺多的。
这个专栏总结了我10年工作中,遇到过的100个非常有代表性的技术问题,非常有参考和学习价值。
Java、Spring、分布式、高并发、数据库、海量数据、线上问题什么都有。
每篇文章从发现问题、分析问题、解决问题和问题总结等多个维度,深入浅出,分享了很多技术细节,定位和排查问题思路,解决问题技巧,以及实际工作经验。
你能从中学到很多有用知识,帮你少走很多弯路。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有