一句话定义虚拟线程是在用户空间(而非内核)中实现的轻量级线程,其创建、调度和销毁由应用程序自己管理,而不依赖于操作系统 。
与传统线程区别传统的线程(也称为物理线程或内核线程)由操作系统内核调度和管理,每个线程都需要分配独立的内存栈和寄存器上下文 。这种线程调度的开销较大,并且线程数量受限于操作系统的限制 。
文章插图
实现方式JAVA 虚拟线程使用的是用户态线程实现,用户态线程是由运行时库实现的线程模型,应用程序可以在用户空间中创建和管理多个线程,而无需涉及操作系统内核 。
文章插图
特点虚拟线程具有以下优点:
- 轻量级:虚拟线程的创建和切换开销相对较低,因为它们在用户空间中实现,不需要操作系统的干预 。
- 高并发性:虚拟线程可以实现更高级别的并发性,应用程序可以创建大量的虚拟线程,而不受操作系统线程数量的限制 。
- 更好的资源利用率:由于虚拟线程是在用户空间中实现的,可以使用更少的物理线程来完成相同数量的任务,从而提供更好的资源利用率 。
- 易于编程:相对于传统线程,虚拟线程的编程模型更简单、直观,可以通过协程或者用户态线程库来实现 。
文章插图
【为什么Java官方不推荐池化虚拟线程?】官方示例:
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
推荐阅读
- JDK为什么废弃永久代,而引入元空间
- Java面试题之SpringBoot 框架
- Java 21:下一个LTS版本,提供了虚拟线程、记录模式和模式匹配
- 为什么会出现“集体咽喉炎”?专家答疑来了
- 拍一拍为什么没有振动 拍一拍后没有提示
- 官方出手!张智霖被带走调查,奢靡生活曝光,垃圾桶都是爱马仕
- 螺丝虾和基围虾的区别 为什么要少吃罗氏虾
- 张杰跟陈楚生、苏醒为什么玩不到一起?有三点原因
- 为什么中年女人出门不建议涂口红?主要有3个原因,看完就知道了
- 光腿神器为啥是双层的 光腿神器为什么是两层