为什么Java官方不推荐池化虚拟线程?

开发 前端
虚拟线程是在用户空间(而非内核)中实现的轻量级线程,其创建、调度和销毁由应用程序自己管理,而不依赖于操作系统。

一句话定义

虚拟线程是在用户空间(而非内核)中实现的轻量级线程,其创建、调度和销毁由应用程序自己管理,而不依赖于操作系统。

与传统线程区别

传统的线程(也称为物理线程或内核线程)由操作系统内核调度和管理,每个线程都需要分配独立的内存栈和寄存器上下文。这种线程调度的开销较大,并且线程数量受限于操作系统的限制。

实现方式

Java 虚拟线程使用的是用户态线程实现,用户态线程是由运行时库实现的线程模型,应用程序可以在用户空间中创建和管理多个线程,而无需涉及操作系统内核。

特点

虚拟线程具有以下优点:

  1. 轻量级:虚拟线程的创建和切换开销相对较低,因为它们在用户空间中实现,不需要操作系统的干预。
  2. 高并发性:虚拟线程可以实现更高级别的并发性,应用程序可以创建大量的虚拟线程,而不受操作系统线程数量的限制。
  3. 更好的资源利用率:由于虚拟线程是在用户空间中实现的,可以使用更少的物理线程来完成相同数量的任务,从而提供更好的资源利用率。
  4. 易于编程:相对于传统线程,虚拟线程的编程模型更简单、直观,可以通过协程或者用户态线程库来实现。

官方使用建议

开发人员通常会将应用程序代码从传统的基于线程池的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


责任编辑:华轩 来源: 今日头条
相关推荐

2024-02-28 07:37:53

JavaExecutors工具

2022-03-02 07:36:37

池化技术Java线程池

2022-01-11 10:29:32

Docker文件挂载

2023-12-20 14:35:37

Java虚拟线程

2020-04-29 14:10:44

Java线程池编程语言

2023-11-03 12:29:48

Java虚拟线程

2021-01-13 09:55:29

try-catch-fJava代码

2019-11-13 14:38:34

Executors阿里线程池

2020-07-02 14:12:52

C++语言编程

2021-08-23 13:02:50

MySQLJOIN数据库

2023-11-06 13:04:59

Python日志库

2020-12-24 18:46:11

Java序列化编程语言

2013-11-11 13:35:44

虚拟化应用

2013-08-29 09:38:32

虚拟化关键业务

2010-10-26 13:44:15

2018-11-29 14:30:42

数据库外键约束应用程序

2021-09-08 07:58:58

字节系统双写

2021-07-04 14:19:03

RabbitMQ消息转换

2020-08-24 10:55:41

数据库双写代码

2020-11-17 10:20:53

Redis多线程单线程
点赞
收藏

51CTO技术栈公众号