虚拟线程是在用户空间(而非内核)中实现的轻量级线程,其创建、调度和销毁由应用程序自己管理,而不依赖于操作系统。
传统的线程(也称为物理线程或内核线程)由操作系统内核调度和管理,每个线程都需要分配独立的内存栈和寄存器上下文。这种线程调度的开销较大,并且线程数量受限于操作系统的限制。
Java 虚拟线程使用的是用户态线程实现,用户态线程是由运行时库实现的线程模型,应用程序可以在用户空间中创建和管理多个线程,而无需涉及操作系统内核。
虚拟线程具有以下优点:
开发人员通常会将应用程序代码从传统的基于线程池的ExecutorService迁移到基于虚拟线程的ExecutorService。线程池就像其他资源池一样,旨在共享昂贵的资源,但虚拟线程并不昂贵,因此无需对它们进行池化。
官方示例:
try (var executor = Executors.newVirtualThreadPerTaskExecutor()) { IntStream.range(0, 10_000).forEach(i -> { executor.submit(() -> { Thread.sleep(Duration.ofSeconds(1)); return i; }); });} // executor.close() is called implicitly, and waits
本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-11826-0.html为什么Java官方不推荐池化虚拟线程?
声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com
上一篇: 2023年前端流行什么技术和框架了?
下一篇: 防御性编码的意识与实践