聊一聊JDK21-虚拟线程

news2025/1/10 16:20:23

目录

前言

Virtual Threads的开始

为什么需要Virtual Threads

JDK19 预览版初次出现

JDK21 Virtual Threads的正式发布

Virtual Threads 该怎么使用

简单聊聊Virtual Threads的实现

使用时候的注意事项

本地尝鲜一下JDK21及Virtual Threads

结语


前言

2023年9月19日,JDK21发布了release版本,首先这是JDK17之后又一个LTS即Oracle官方会长期支持的版本,这个版本带来了很多新的特性,例如:

  • 虚拟线程

  • 分代ZGC

  • switch关键字模式匹配

...等等 详细的特性,请皇上查阅以下链接。

https://openjdk.org/projects/jdk/21/

https://jdk.java.net/21/release-notes 

其中最让人关注的当属从JDK19就提出的Virtual Threads,终于作为JDK21的feature正式可以使用了,在经历了两年的preview版本之后,终于和大家见面了Virtual Threads可以说是近些年来,JDK最让人兴奋,也是讨论最多的特性。

今天就和大家来讨论下JEP444:Virtual Threads 虚拟线程。


Virtual Threads的开始

相对于近些年来炙手可热的Go来说,Java算得上一个老前辈了,Java全面的功能,完整的生态,无数开发者的支持,也不算弱的性能,让Java在服务端开发上仍是TOP级别。

但是,大人,时代变了。

Go虽然也不算横空出世,发展了10多年之后,终于在云原生时代崛起,其极佳的性能表现在k8s等基础设施的服务端开放上,有着很大的优势。

虽然Go作为近些年崛起的语言仍然有着不太完备的表现,像2022年才支持的泛型、Go modules、异常处理等基础为开发人员诟病。

但是Go语言的并发处理方式,非常的轻量级,且易于使用,如果你想并发地运行一个函数,只需要使用 go function(arguments)。如果你需要让函数间进行通信,你可以使用通道,这些通道默认会同步执行,即在两端都准备就绪前,会暂停执行。 goroutine、GC机制、快速的编译时间等等强大特性,吸引了众多的开发者在越来越多的服务端应用上使用。

对于进程和线程等不再赘述,可看下图。

Go语言的协程,相比于Java,其更好的性能表现、更轻量级、不需要操作系统调度让很多Java开发者垂涎,盼星星盼月亮,也希望Java什么时候也能老树逢春,久旱逢甘霖。

其实很早之前Oracle官方就传出了要给JDK搞一个轻量级线程,我记得最早很多人把它叫做纤程(fibers),听起来就很轻很细~。

这个项目被Oracle官方称为loom,两年前在极客上看到有文章分享之后,之后一直收藏关注。 有兴趣的童鞋可以看看下面两篇loom官方的介绍。

https://openjdk.org/projects/loom/ 
https://cr.openjdk.org/~rpressler/loom/loom/sol1_part1.html 


为什么需要Virtual Threads

Virtual Threads的出现解决了什么问题,相对于之前的操作系统线程或者说平台线程(Platform Threads)有什么优势。

JVM使用平台线程和操作系统线程是一一对应的,有些使用的缺点在Java不断地发展中不断地凸显出来

  • 创建单个线程所需资源过多,平台线程本身就是很珍贵的资源

  • 受限于机器硬件,平台线程的个数不能创建过多,且创建及回收线程需要耗费一定资源

    我们不可能为每个请求或者说任务分配一个单独的线程,当请求量达到一定阈值之后,只能通过线程池或者其他异步的方式来处理请求。

  • Java运行中线程上下文的切换非常频繁,切换需要的资源也耗费不少

那么Virtual Threads是如何应对这些问题的呢?

  • Virtual Threads的关键特点是便宜、数量多、轻量级,相对于OS线程代价可能只是千分之一。

  • 无需池化使用,寿命周期短

  • 每个请求都创建一个虚拟线程,无需上下文切换 thread-per-request style

  • 由OS线程装载Virtual Threads,并随时可以卸载(特殊同步代码块除外),然后执行其他Virtual Threads


JDK19 预览版初次出现

在从2017年loom项目正式开始,Virtual Threads的推进算是比较迅速的,JDK19除了预览版之后,很多大佬都对此表示肯定。

相比较后面JDK21的release版本, JDK19的预览版基本没有什么太大的区别,无非是一些细节上的完善以及JDK内部对Virtual Threads的应用。


JDK21 Virtual Threads的正式发布

两年后的现在,千呼万唤始出来,JDK21在9月19日正式发布。Virtual Threads作为正式的Feature亮相。


Virtual Threads 该怎么使用

先看下说明,为了方便用户使用,JDK提供了一系列使用虚拟线程的API,并且兼容之前线程的使用方式,无需为使用虚拟线程而重写应用程序。

1.使用静态构造器方法(新API)

          Thread.startVirtualThread(() -> {
            System.out.println(Thread.currentThread());
        });

        Thread.ofVirtual().start(() -> {
            System.out.println(Thread.currentThread());
        });

2.使用Executors创建虚拟线程池

ExecutorService executor = Executors.newVirtualThreadPerTaskExecutor();

上述代码会创建一个无限的虚拟线程池。


简单聊聊Virtual Threads的实现

首先需要明确的是Virtual Threads是基于平台线程(OS线程)运行的,并且是由JVM创建并管理的。

它是由JVM调度,mounting (装载)到OS线程上执行的,当阻塞的时候,再从OS线程上unmounting(卸载),OS线程可以继续mounting其他的虚拟线程,继续执行。

后面几天好好再研究下Virtual Threads的实现,以及和Go协程实现的区别,完事儿再输出下。

        


使用时候的注意事项

  • Thread.setPriority(int) 和 Thread.setDaemon(boolean) 这俩方法对虚拟线程不起作用

  • Thread.getThreadGroup() 会返回一个虚拟的空VirtualThreads group。

  • 同一个任务使用Virtual Threads和Platform Threads执行效率上是完全一样的,并不会有什么性能上的提升

  • 尽量使用JUC包下的并发控制例如ReentrantLock来进行同步控制,而不使用synchronized

    synchronized 同步代码块会pinning(别住或者说Block)虚拟线程,这点JDK官方说后面有可能会优化这点

  • Virtual Threads 被设计成final类,并不能使用子类来继承

  • 不适用于计算密集型任务: 虚拟线程适用于I/O密集型任务,但不适用于计算密集型任务,因为它们在同一线程中运行,可能会阻塞其他虚拟线程

  • 新特性自然有很多BUG,这点在JDK的Issue中确实也体现了,使用请慎重!!


本地尝鲜一下JDK21及Virtual Threads

  • Oracle官方下载OpenJDK21

  • 修改本地系统的环境变量path,JAVA_HOME都指向JDK21即可

  • 可以尝试编写尝Demo

  • javac -Demo.java 编译,java -Demo 执行


结语

除了Virtual Threads外,JDK21还有两个让人兴奋的特性

  1. 分代ZGC

ZGC发布的当初,不分代也是其当时被人津津乐道的特性,如今也走上了CMS、G1的路子开始分代,毕竟其远超G1的内存占用会影响到吞吐量,不知道是否会影响ZGC的核心特性超低延迟

  1. 结构性并发

在当时刚看到Virtual Threads时,一眼就看到了这个特性的介绍,如今在JDK21中 Structured Concurrency in JDK 21: A Leap Forward in Concurrent Programming

后续可以再详细聊一聊

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1048676.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

26272-2010 地面数字电视调谐器基本性能要求和测量方法.

声明 本文是学习GB-T 26272-2010 地面数字电视调谐器基本性能要求和测量方法. 而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 1 范围 本标准规定了地面数字电视接收设备用特高频/超高频(VHF/UHF) 电子式调谐器基本性能要求 和测量方法。 本标准适用…

数据结构与算法(C语言版)P8---树、二叉树、森林

【本节目标】 树概念及结构。二叉树概念及结构。二叉树常见OJ题练习。 1、树概念及结构 1.1、树的概念 树是一种非线性的数据结构,它是由n(n>0)个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一颗倒挂的树&#xf…

再看dockerfile指令用法:80分钟一口气学完docker+k8s!带你掌握docker+k8s所有核心知识点,全程干货,无废话!

dockerfile实践 需求:通过dockerfile,构建nginx镜像,且容器运行后,生成的页面显示“书季,要攒劲哦~” #1、穿件dockerfile,注意文件名必须是这个。 [rootHadoop2 learn_docker]# cat dockerfile FROM nginx RUN echo…

linux opensuse使用mtk烧录工具flashtool

环境 linux发行版:opensuse leap 15.5 工具:SP_Flash_Tool_Selector_exe_Linux_v1.2316.00.100.rar 或其他版本 目标:mtk设备 下载链接 https://download.csdn.net/download/zmlovelx/88382784 或网络搜索。 使用 opensuse可直接解压后使…

HOMER7配置告警

概述 HOMER是一款100%开源的针对SIP/VOIP/RTC的抓包工具和监控工具。 HOMER是一款强大的、运营商级、可扩展的数据包和事件捕获系统,是基于HEP/EEP协议的VoIP/RTC监控应用程序,并可以使用即时搜索、处理和存储大量的信令、RTC事件、日志和统计信息。 …

【数据仓库设计基础(二)】维度数据模型

文章目录 一. 概述二. 维度数据模型建模过程三. 维度规范化四. 维度数据模型的特点五. 维度数据模型1. 星型模式1.1.事实表1.2.维度表1.3.优点1.4.缺点1.5.示例 2. 雪花模式2.1.数据规范化与存储2.2&#x…

PreMaint设备管理系统:实现制药企业的CSV合规性

在当今数字化时代,制药企业越来越依赖计算机化系统来支持其各个方面的运营,从研发到生产再到质量控制。然而,这些系统的使用不仅需要高效性和可靠性,还需要符合法规要求,尤其是药品生产质量管理规范(Good M…

新零售革命:可视化助力零售业焕发新生

一、什么是新零售? 新零售是一种融合了传统零售业和数字科技的商业模式,旨在提升零售业的效率、便捷性和个性化。它将线上和线下的零售渠道结合在一起,通过数字技术、大数据分析、人工智能等手段,实现了以下几个主要特征和目标&a…

图像语义分割 FCN图像分割网络详解

图像语义分割 FCN图像分割网络详解 0、介绍1、VGG16网络结构2、转置卷积3、FCN-32S、FCN-16S,FCN-8S网络结构4、损失函数5、膨胀卷积6、FCN(Backbone-ResNet-50)6.1 项目框架6.2 ResNet50网络结构6.3 FCN(Backbone-ResNet-50)网络结构6.4 FCN(Backbone-ResNet-50)模…

基于SpringBoot的大学生就业招聘系统的设计与实现

目录 前言 一、技术栈 二、系统功能介绍 求职信息管理 首页 招聘信息管理 岗位申请管理 岗位分类 企业管理 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 随着信息互联网信息的飞速发展,大学生就业成为一个难题,好多公司都舍不…

【RV1103】Luckfox Pico RV1103 开发记录

文章目录 对比uboot的差别Linux的差别其他差别编译命令对比板级配置选择spi-nand flashemmc/SD 卡spinand flash烧录差别由于没有原理图--引脚分析 对比 linux defconfiglinux dtsuboot defconfiguboot fragmentluckfox-picosd/tf (emmc)luckfox_rv1106_linux_defconfigrv1103…

澳大利亚海运价格下半年走势

随着全球疫情的逐渐缓解,国际贸易开始逐步恢复。在这个过程中,澳大利亚作为全球重要的贸易伙伴,其海运价格也成为了市场关注的焦点。本文将从下半年的市场预期、影响因素以及行业动态等方面,对澳大利亚海运价格走势进行分析展望。…

祝贺莱佛士学生在ASDA2023设计大赛中获得最高奖项

莱佛士一直主张学生们积极参与各种国际知名的设计大赛,也会竭尽所能为学生们的参赛提供途径与指导,本次的American Standard Design Award(ASDA)2023设计大赛也不例外。 ASDA2023设计大赛,推广以用户为中心的设计理念…

极简非凡react hooks+arcoDesign+vite后台管理模板

最近捣鼓了一个vite4搭建react18后台模板,搭载了字节团队react组件库Arco Design,整体编译运行顺滑衔接。支持多种模板布局、暗黑/亮色模式、国际化、权限验证、多级路由菜单、tabview标签栏快捷菜单、全屏控制等功能。 使用技术 "arco-design/web…

攀登数字化高峰,中小企业如何找“搭子”?

相信大多数人都认可,中小企业数字化,是一条充满未知和艰辛的征程。 这个过程,不是租几台云服务器、开发几个APP那么简单,而是一个对组织架构、业务环节、基础设施、商业模式等进行量身定制、长期迭代的体系化工程,需要…

船用白炽照明灯具

声明 本文是学习GB-T 3027-2012 船用白炽照明灯具. 而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 1 范围 本标准规定了船用白炽照明灯具(以下简称灯具)的要求、试验方法、检验规则、标识、包装和储 存等。 本标准适用于电源电压在250V 以下的交流…

uni-app使用iconfont字体图标

先iconfont选择好自己需要的图标 添加至项目 下载字体文件到本地 将下载的文件解压缩到工程目录static文件夹下 定义好iconfont.css文件的font-face声明,修改好引入的url地址 打开App.vue文件 ,引入static下刚才修改的iconfont.css字体图标文件 完成上线的步骤后就可以全局使用…

matplotlib绘图实现中文宋体的两种方法(亲测)

方法一:这种方法我没有测试。 第一步 找宋体字体 (win11系统) 2.matplotlib字体目录,如果不知道的话,可以通过以下代码查询: matplotlib.matplotlib_fname() 如果你是Anaconda3 安装的matplotlib&#x…

不同组合地下管线的地质雷达响应特征分析

不同组合地下管线的地质雷达响应特征分析 前言 以混凝土管线为例,建立水平相邻管线电性模型,管径为60cm,中心埋深为70cm,管线长度为150cm,分别建立管线圆心相距150cm的两根相邻双管线和三管线模型,进行二…

SQL血缘解析原理

根据sql解析获取到表到表, 字段到字段间的关系,即血缘关系。实际上这是从sql文本获取到数据流的过程。 大致步骤如下: 1.sql文本进行词法分析 2.sql语法分析获取到AST抽象语法树 3.访问AST抽象语法树根据语法结构推测出数据的流向,例如create as select from 这种结…