劲爆!Java 协程要来了。。。
扫描二维码
随时随地手机看文章
我们都知道,Java 目前最小的系统调度单元只支持线程,官方是不支持协程的,但可以通过第三方框架实现,估计也很少有人会用吧,多线程就能满足需求。好消息来了,不久的将来,Java 要开始支持协程了,这真是劲爆消息啊!!在 openjdk 的官网上,2021/11/15 这天创建了一个新的特性:JEP draft: Virtual Threads (Preview)虚拟线程,我们来看看是什么鬼:虚拟线程是一种成本低廉、轻量级的用户模式的线程实现,它可以充分利用可用硬件,大幅减少编写、维护和监测高并发应用的工作量。低成本+轻量级+用户态,这一看就是协程 的定义了。。我们都知道使用线程是要十分注意的,因为线程的创建、销毁都十分消耗系统资源,所以有了线程池,但这还不够,因为线程的数量是有限的,线程会阻塞操作系统线程,无法尽可能的提高吞吐量。因为使用线程的成本很高,所以才会有了虚拟线程,它是用户态线程,成本是相当低廉的,调度也完全由用户进行控制(JDK 中的调度器),它同样可以进行阻塞,但不用阻塞操作系统线程,充分提高了硬件利用率,高并发也上了一个量级,从而实现了高吞吐量。虚拟线程创建方式:虚拟线程是
java.lang.Thread的一个实现,可以使用
java.lang.Thread.Builder接口创建,如下所示:
Thread thread = Thread.ofVirtual()
.name("javastack")
.unstarted(runnable);
也可能会通过一个线程工厂类进行创建:
ThreadFactory factory = Thread.ofVirtual().factory();
并且,可以通过 Thread.isVirtual() 方法判断是否虚拟线程。