Java21中的新特性虚拟线程详解

简介: ​Java21中新引入虚拟线程是一种线程抽象,它提供了一种轻量级的线程实现方式,可以在用户级别进行线程调度和管理。它本身是基于操作系统级别的线程的,但是由JVM调度的,因此不需要系统内核的介入,减少了线程调度的开销。虚拟线程的思想是在操作系统线程的基础上增加一个轻量级并发调度对象,原有操作系统线程发生阻塞时往往需要进行开销非常大的上下文切换才能完成调度,但是在虚拟线程发生阻塞时将同属一个操作系统线程的另外一个虚拟线程进行调度运行是一个开销比较低的方式,这将大幅提升Java的并发能力,可以说在这个并发为王的时代对于并发能力的大幅提升也是虚拟线程在Java21中被称作史诗级更新的原因。


Java21中新引入虚拟线程是一种线程抽象,它提供了一种轻量级的线程实现方式,可以在用户级别进行线程调度和管理。它本身是基于操作系统级别的线程的,但是由JVM调度的,因此不需要系统内核的介入,减少了线程调度的开销。虚拟线程的思想是在操作系统线程的基础上增加一个轻量级并发调度对象,原有操作系统线程发生阻塞时往往需要进行开销非常大的上下文切换才能完成调度,但是在虚拟线程发生阻塞时将同属一个操作系统线程的另外一个虚拟线程进行调度运行是一个开销比较低的方式,这将大幅提升Java的并发能力,可以说在这个并发为王的时代对于并发能力的大幅提升也是虚拟线程在Java21中被称作史诗级更新的原因。

一、虚拟线程简介
1.虚拟线程和操作系统线程(传统Java线程)的比较
1)传统Java线程:
传统是由操作系统级别的线程,需要在JVM外部进行管理和调度。

2)虚拟线程
虚拟线程则是由JVM内部实现的,可以在JVM内部进行管理和调度。

2.虚拟线程的优势
1)轻量级
虚拟线程的创建、销毁和切换开销比操作系统级别的线程更小。

2)可管理性
虚拟线程可以在用户级别进行线程管理,提供了更高的可控性。

3)高并发
虚拟线程可以同时创建大量的线程,支持更高的并发度。

3.Java虚拟线程和Goroutine的比较
1)相同点
Java虚拟线程和Goroutine都是为了解决高并发场景下的线程管理问题而设计的。

2)不同点
Goroutine由Go语言实现,是Go语言的特色之一,它通过协程调度实现并发。它与虚拟线程最显著的区别在于虚拟线程是基于操作系统线程的,同一组虚拟线程基于一个操作系统线程运行,因此无法进行跨核调度,也就是说当前操作系统线程运行所在的CPU核心就是虚拟线程运行所在的核心,而Goroutine则没有这个限制,同一组Goroutine也完全可能运行在不同核心上。

综上可以看到Java虚拟线程和Goroutine不是一个层面上的并发执行工具,放在一起进行性能比较意义不大。

二、虚拟线程的使用场景
1.虚拟线程示例
import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
public class VirtualThreadExample {
public static void main(String[] args) {
ExecutorService executor = Executors.newVirtualThreadPerTaskExecutor(Executors.newCachedThreadPool());
for (int i = 0; i < 10; i++) {
executor.submit(() -> {
System.out.println("任务" + Thread.currentThread().getName() + "开始执行");
try {
TimeUnit.SECONDS.sleep(2);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("任务" + Thread.currentThread().getName() + "执行完成");
});
}
executor.shutdown();
}
}

这个示例中,我们使用了Executors.newVirtualThreadPerTaskExecutor方法创建一个虚拟线程的执行器,这个执行器在每次提交一个新任务时,都会为这个任务创建一个新的虚拟线程来执行它。这意味着每个任务都有自己的虚拟线程,不会与其他任务共享操作系统线程。这与传统的线程池思想不同,传统的线程池通常会重用线程池中的空闲线程来执行新的任务。

这个执行器使用了一个缓存线程池作为它的底层线程池。这意味着如果一个任务提交后,没有可用的虚拟线程来执行它,那么这个任务会被放到一个缓存队列中,等待一个虚拟线程空闲出来。如果缓存队列已满,而且所有的虚拟线程都在忙,那么这个任务会被拒绝。

2.虚拟线程应用场景
1)促销秒杀场景
在促销秒杀业务场景中,可以利用虚拟线程实现高并发、低延迟的应用。例如,金融应用服务器可以利用虚拟线程实现多线程业务逻辑,提高交易响应的流畅度和响应速度。

2)WEB应用中处理HTTP请求
在Web应用中,可以使用虚拟线程来处理高并发的HTTP请求,提高Web服务器的吞吐量和响应速度。

3)大数据处理
在大数据处理中,可以使用虚拟线程来处理海量数据,提高数据处理速度和效率。

3.虚拟线程应用时的注意事项
1)虚拟线程是基于操作系统线程的的优化而并非革命
虚拟线程不能完全解决多线程并发问题,因为即使有了虚拟线程,同一时间也只能有一个线程在执行,而不能真正实现并行执行。

2)注意并发竞争时的线程安全问题
虚拟线程不能彻底解决线程安全问题,因为虚拟线程仍然存在竞争条件和死锁等问题,而一旦出现死锁等严重问题后果非常严重。

3)小心内存泄露
由于虚拟线程的上下文信息是与操作系统线程一起共享的,因此如果虚拟线程过多,且有的虚拟线程未正常关闭,可能会导致内存泄漏问题,因此虚拟线程的处理中要特别注意Finally代码段时释放内存并关闭网络连接。

三、虚拟线程未来展望
个人认为未来Java虚拟线程将会不断优化性能,甚至引入全新的调度模型来进一步提高并发处理能力和系统吞吐量,并完善安全机制,防止非法访问和操作,保护系统的安全性和稳定性。

相关文章
|
1月前
|
存储 安全 Java
Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
【10月更文挑战第17天】Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
60 2
|
1月前
|
存储 Java
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
39 3
|
1月前
|
存储 Java 数据处理
Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位
【10月更文挑战第16天】Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位。本文通过快速去重和高效查找两个案例,展示了Set如何简化数据处理流程,提升代码效率。使用HashSet可轻松实现数据去重,而contains方法则提供了快速查找的功能,彰显了Set在处理大量数据时的优势。
33 2
|
1月前
|
存储 算法 Java
Java Set因其“无重复”特性在集合框架中独树一帜
【10月更文挑战第14天】Java Set因其“无重复”特性在集合框架中独树一帜。本文深入解析Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定的数据结构(哈希表、红黑树)确保元素唯一性,并提供最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的`hashCode()`与`equals()`方法。
31 3
|
1月前
|
安全 Java API
Java 17新特性让你的代码起飞!
【10月更文挑战第4天】自Java 8发布以来,Java语言经历了多次重大更新,每一次都引入了令人兴奋的新特性,极大地提升了开发效率和代码质量。本文将带你从Java 8一路走到Java 17,探索那些能让你的代码起飞的关键特性。
83 1
|
16天前
|
分布式计算 Java API
Java 8引入了流处理和函数式编程两大新特性
Java 8引入了流处理和函数式编程两大新特性。流处理提供了一种声明式的数据处理方式,使代码更简洁易读;函数式编程通过Lambda表达式和函数式接口,简化了代码书写,提高了灵活性。此外,Java 8还引入了Optional类、新的日期时间API等,进一步增强了编程能力。这些新特性使开发者能够编写更高效、更清晰的代码。
28 4
|
30天前
|
存储 Java API
优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。
【10月更文挑战第19天】本文介绍了如何优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。内容包括Map的初始化、使用Stream API处理Map、利用merge方法、使用ComputeIfAbsent和ComputeIfPresent,以及Map的默认方法。这些技巧不仅提高了代码的可读性和维护性,还提升了开发效率。
58 3
|
30天前
|
存储 安全 Java
Java Map新玩法:深入探讨HashMap和TreeMap的高级特性
【10月更文挑战第19天】Java Map新玩法:深入探讨HashMap和TreeMap的高级特性,包括初始容量与加载因子的优化、高效的遍历方法、线程安全性处理以及TreeMap的自然排序、自定义排序、范围查询等功能,助你提升代码性能与灵活性。
24 2
|
1月前
|
Java 开发者
在Java的集合世界里,Set以其独特的特性脱颖而出,它通过“哈希魔法”和“红黑树防御”两大绝技
【10月更文挑战第13天】在Java的集合世界里,Set以其独特的特性脱颖而出。它通过“哈希魔法”和“红黑树防御”两大绝技,有效抵御重复元素的侵扰,确保集合的纯洁性和有序性。无论是“人海战术”还是“偷梁换柱”,Set都能从容应对,成为开发者手中不可或缺的利器。
31 6
|
1月前
|
Java 开发者
在Java集合世界中,Set以其独特的特性脱颖而出,专门应对重复元素
在Java集合世界中,Set以其独特的特性脱颖而出,专门应对重复元素。通过哈希表和红黑树两种模式,Set能够高效地识别并拒绝重复元素的入侵,确保集合的纯净。无论是HashSet还是TreeSet,都能在不同的场景下发挥出色的表现,成为开发者手中的利器。
27 2
下一篇
无影云桌面