说明
虚拟线程(Virtual Threads)是在 Project Loom 中开发的,并从 Java SE 19 开始作为预览功能引入 JDK。
在线程模型下, 一个 Java 线程相当于一个操作系统线程 ,而这些线程是很消耗资源的,如果启动的线程过多,会给整个系统的稳定性带来风险。
虚拟线程解决了这个问题,从 Java 代码的角度来看,虚拟线程感觉就像普通的线程,但它们不是 1:1
地映射到操作系统线程上。
有一个所谓的载体线程池,一个虚拟线程被临时映射到该池中。一旦虚拟线程遇到阻塞操作,该虚拟线程就会从载体线程中移除,而载体线程可以执行另一个虚拟线程(新的或之前被阻塞的)。
所以阻塞的操作不再阻塞执行的线程。这使得我们可以用一个小的载体线程池来并行处理大量的请求。
示例
场景
启动 1000 个任务,每个任务等待一秒钟(模拟访问外部API),然后返回一个结果(在这个例子中是一个随机数)。
任务类如下
package git.snippets.vt; import java.util.concurrent.Callable; import java.util.concurrent.ThreadLocalRandom; /** * @author <a href="mailto:410486047@qq.com">Grey</a> * @date 2022/9/21 * @since