当前位置:首页 > 科技  > 软件

JDK21 性能提升20倍

来源: 责编: 时间:2023-10-20 10:02:04 189观看
导读大家好,我是了不起。JDK21 发布已经过去1个月时间了,除了每次发版必然更新的GC机制,和一些增强功能外,还引入了一个全新的概念——虚拟线程。什么是虚拟线程先来看一下官方对虚拟线程(Visual Threads)的描述(已翻译):如今,JD

大家好,我是了不起。jHq28资讯网——每日最新资讯28at.com

JDK21 发布已经过去1个月时间了,除了每次发版必然更新的GC机制,和一些增强功能外,还引入了一个全新的概念——虚拟线程。jHq28资讯网——每日最新资讯28at.com

什么是虚拟线程

先来看一下官方对虚拟线程(Visual Threads)的描述(已翻译):jHq28资讯网——每日最新资讯28at.com

如今,JDK中java.lang.Thread的每个实例都是一个平台线程。平台线程在底层操作系统线程上运行Java代码,并在代码的整个生命周期中捕获操作系统线程。平台线程的数量限制为操作系统线程的数量。jHq28资讯网——每日最新资讯28at.com

虚拟线程是java.lang.thread的一个实例,它在底层操作系统线程上运行java代码,但在代码的整个生命周期内不会捕获该操作系统线程。这意味着许多虚拟线程可以在同一个操作系统线程上运行Java代码,从而有效地共享代码。jHq28资讯网——每日最新资讯28at.com

虽然平台线程独占了宝贵的操作系统线程,但虚拟线程却没有。虚拟线程的数量可以比操作系统线程的数量大得多。jHq28资讯网——每日最新资讯28at.com

虚拟线程是JDK而不是OS提供的线程的轻量级实现。它们是用户模式线程的一种形式,在其他多线程语言中也很成功(例如Go中的goroutines和Erlang中的processes)。用户模式线程甚至在早期版本的Java中被称为“绿色线程”,当时操作系统线程还不成熟和广泛使用。然而,Java的绿色线程都共享一个操作系统线程(M:1调度),并且最终被平台线程所超越,后者被实现为操作系统线程的包装器(1:1调度)。虚拟线程采用M:N调度,其中大量(M)虚拟线程被调度在少量(N)OS线程上运行。jHq28资讯网——每日最新资讯28at.com

简而言之,现在我们可以轻松地创建一个轻量级的虚拟线程,实现简单性,同时充分发挥硬件性能。jHq28资讯网——每日最新资讯28at.com

可以概括为: 轻量、多路复用、开销极小、异步编程、可移植性jHq28资讯网——每日最新资讯28at.com

测试

开始一个简单的测试:1万并发阻塞1秒模仿web连接池,使用Thread.sleep(1) 模拟IO操作需要的时间。jHq28资讯网——每日最新资讯28at.com

public static void main(String[] args) throws InterruptedException {    long l = System.currentTimeMillis();//    normal();    virtual();    System.out.println(System.currentTimeMillis() - l);}

先使用常规线程池方式运行:jHq28资讯网——每日最新资讯28at.com

public static void normal() throws InterruptedException {    ExecutorService executor = Executors.newFixedThreadPool(200);    for (int i=0; i < 10000; i++) {        executor.execute(() -> {            try {                System.out.println("normal");                Thread.sleep(1000);            } catch (InterruptedException e) {                e.printStackTrace();            }        });    }    executor.shutdown();    executor.awaitTermination(100, java.util.concurrent.TimeUnit.SECONDS);}

得到如下结果:jHq28资讯网——每日最新资讯28at.com

图片图片jHq28资讯网——每日最新资讯28at.com

使用 JDK21 虚拟线程池运行:jHq28资讯网——每日最新资讯28at.com

public static void virtual() throws InterruptedException {    ExecutorService executor = Executors.newVirtualThreadPerTaskExecutor();    for (int i=0; i < 10000; i++) {        executor.execute(() -> {            try {                System.out.println("jdk21");                Thread.sleep(1000);            } catch (InterruptedException e) {                e.printStackTrace();            }        });    }    executor.shutdown();    executor.awaitTermination(100, java.util.concurrent.TimeUnit.SECONDS);}

得到如下结果:jHq28资讯网——每日最新资讯28at.com

图片图片jHq28资讯网——每日最新资讯28at.com

20多倍的提速!!!jHq28资讯网——每日最新资讯28at.com

我不理解,但我大受震撼!!!jHq28资讯网——每日最新资讯28at.com

如果有朋友想自己测试一下虚拟线程,或者JDK21的其他新特性,可以尝试一下哦~jHq28资讯网——每日最新资讯28at.com

JDK21 官网下载链接:https://download.oracle.com/graalvm/21/latest/graalvm-jdk-21_windows-x64_bin.zipjHq28资讯网——每日最新资讯28at.com

目前虚拟线程还属于预览版本,没有正式启用。如果是IDEA 开发工具,在启动的时候,需要配置VM参数 --enable-previewjHq28资讯网——每日最新资讯28at.com

图片图片jHq28资讯网——每日最新资讯28at.com

小结

经过测试,在该例子中,Executors.newFixedThreadPool( size ); size的值越大,普通的线程池用时越短,在线程池的大小开放到 10000后,用时几乎一样。jHq28资讯网——每日最新资讯28at.com

应该是本例的IO操作是Thread.sleep的缘故,所以不会占用CPU资源。jHq28资讯网——每日最新资讯28at.com

传统的线程池,一般我们会指定核心线程数量为 CPU核心数*4,最大线程数为 CPU核心数*8,而在虚拟线程池中,不需要指定线程数,JDK会自动根据资源占用情况,创建合适数量的线程,追求更高的吞吐量。jHq28资讯网——每日最新资讯28at.com

听说springboot3.2.0版本开始,springboot要把webflux底层也改成虚拟线程了,不知道以后会不会把所有的关于异步线程的地方都改成虚拟线程。jHq28资讯网——每日最新资讯28at.com

了不起是觉得这个虚拟线程真是个好东西,简单易用,再也不纠结怎么配置线程池,根据硬件自适应,效率极高。jHq28资讯网——每日最新资讯28at.com

现在Spring6是基于JDK17的,不知道下个大版本更新会不会直接更新到有虚拟线程稳定发布的JDK版本,期待!jHq28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-14312-0.htmlJDK21 性能提升20倍

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 详细解读HTTP/1.0、HTTP/1.1和HTTP/2.0,HTTPS之间的区别

下一篇: 前端项目重构的深度思考和复盘

标签:
  • 热门焦点
  • 28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解
  • 多线程开发带来的问题与解决方法

    多线程开发带来的问题与解决方法

    使用多线程主要会带来以下几个问题:(一)线程安全问题  线程安全问题指的是在某一线程从开始访问到结束访问某一数据期间,该数据被其他的线程所修改,那么对于当前线程而言,该线程
  • 使用AIGC工具提升安全工作效率

    使用AIGC工具提升安全工作效率

    在日常工作中,安全人员可能会涉及各种各样的安全任务,包括但不限于:开发某些安全工具的插件,满足自己特定的安全需求;自定义github搜索工具,快速查找所需的安全资料、漏洞poc、exp
  • 共享单车的故事讲到哪了?

    共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 本地生活这块肥肉,拼多多也想吃一口

    本地生活这块肥肉,拼多多也想吃一口

    出品/壹览商业 作者/李彦编辑/木鱼拼多多也看上本地生活这块蛋糕了。近期,拼多多在App首页&ldquo;充值中心&rdquo;入口上线了本机生活界面。壹览商业发现,该界面目前主要
  • 品牌洞察丨服务本地,美团直播成效几何?

    品牌洞察丨服务本地,美团直播成效几何?

    来源:17PR7月11日,美团App首页推荐位出现&ldquo;美团直播&rdquo;的固定入口。在直播聚合页面,外卖&ldquo;神枪手&rdquo;直播间、美团旅行直播间、美团买菜直播间等均已上线,同时
  •  首发天玑9200+ iQOO Neo8系列发布首销售价2299元起

    首发天玑9200+ iQOO Neo8系列发布首销售价2299元起

    2023年5月23日晚,iQOO Neo8系列正式发布。其中,Neo系列首款Pro之作——iQOO Neo8 Pro强悍登场,限时售价3099元起;价位段最强性能手机iQOO Neo8同期上市
  • OPPO K11采用全方位护眼屏:三大护眼能力减轻视觉疲劳

    OPPO K11采用全方位护眼屏:三大护眼能力减轻视觉疲劳

    日前OPPO官方宣布,全新的OPPO K11将于7月25日正式发布,将主打旗舰影像,和同档位竞品相比,其最大的卖点就是将配备索尼IMX890主摄,堪称是2000档位影像表
  • 华为举行春季智慧办公新品发布会 首次推出电子墨水屏平板

    华为举行春季智慧办公新品发布会 首次推出电子墨水屏平板

    北京时间2月27日晚,华为在巴塞罗那举行春季智慧办公新品发布会,在海外市场推出之前已经在中国市场上市的笔记本、平板、激光打印机等办公产品,并首次推出搭载
Top
Baidu
map