劲爆!Java 协程要来了。。。

Java技术栈

共 1742字,需浏览 4分钟

 · 2021-12-14

点击关注公众号,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() 方法判断是否虚拟线程。

虚拟线程运行的载体必须是线程,同一个线程中可以运行多个虚拟线程实例。


目前这还是个草案,预览特性,很多细节并不是很确定,是不是叫协程?或者纤程?还是虚拟线程?现在也没有官方的中文资料,叫什么不重要,我们都知道的是,Java 中的 "协程" 它要来了!

有了协程,Java 的并发能力将会再上 N 个台阶……

我们还是拭目以待吧,目前最新版本是JDK 17,看它在哪个 JDK 版本中落地,到时候栈长再给大家解读分享,大家可以持续关注公众号Java技术栈,公众号第一时间推送,不要走开哦,多线程教程也写了一堆了,可以在公众号菜单中阅读。

具体细节和后续的的进展可以参考官方说明:

https://openjdk.java.net/jeps/8277131

好了,今天的分享就到这里了,后面栈长会分享更多好玩的 Java 技术和最新的技术资讯,关注公众号Java技术栈第一时间推送,我也将主流 Java 面试题和参考答案都整理好了,在公众号后台回复关键字 "面试" 进行刷题。

最后,你觉得 Java 为什么到现在才开始考虑协程?欢迎留言讨论!

这真是个劲爆好消息,转发、分享给更多 Javaer 小伙伴们吧!

版权声明:本文系公众号 "Java技术栈" 原创,原创实属不易,转载、引用本文内容请注明出处,抄袭者一律举报+投诉,并保留追究其法律责任的权利。



23 种设计模式实战(很全)
官宣:Redis OM 对象映射框架来了!
你还在遍历搜索集合?Java 8 一行代码搞定!
JetBrains 发布下一代 IDE,IDEA 可以扔了
重磅!JDK 17 发布,正式免费。。
面试官:Java 8 map 和 flatMap 的区别?
终于!Spring Cloud 2021 正式发布。。
推荐一款代码神器,代码量至少省一半!
程序员精通各种技术体系,45岁求职难!
重磅!Spring Boot 2.6 正式发布
Spring Boot 学习笔记,这个太全了!



关注Java技术栈看更多干货



获取 Spring Boot 实战笔记!
浏览 13
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报