百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

与 Java 17 相比,Java 21 究竟有多快?

yuyutoo 2024-10-23 16:40 8 浏览 0 评论

随着 Java 21 的发布已经进入了倒计时阶段,你可能想知道它与 Java 17 相比,有什么不同以及是否应该升级。基于此,开源软件公司 Timefold 进行了梳理与实测,借助自家的 Timefold Solver 工具分享了 Java 21 的真实运行情况(与 Java 17 相比)。

原文链接:https://timefold.ai/blog/2023/java-21-performance/

未经允许,禁止转载!

作者|Luká? Petrovicky

译者|Ric Guan 责编|屠敏

出品|CSDN (ID:CSDNnews)

首先,让我们先明确一些事情:

什么是 Java 21 以及如何获取它

Java 21 是 Java 平台的新版本,Java 平台是编写 Timefold Solver 的可靠编程语言。它带来了许多新功能,以及常见的问题修复和较小的改进。

Java 21 将于 2023 年 9 月 19 日全面发布,但你现在可以使用候选版本构建进行尝试。我们发现开始使用 Java 21 的最简单方法是使用 SDKMAN(https://sdkman.io/),我们也是这样做的。

与之前的 Java 17 一样,Java 21 是一个长期支持 (LTS) 版本;它会持续很长一段时间。因此,最好尽快开始使用它,看看它是否适合你。

对于 Timefold Solver 来说,这意味着确保整个代码库在 Java 21 上完美运行,并运行一些基准测试以确保我们的用户至少可以获得与以前相同的性能。让我们开始吧。

微基准测试

我们将从分数总监微基准开始,我们定期使用它来确定各种变化对约束流性能的影响。这些基准测试并不运行整个求解器;相反,他们只专注于求解器的分数计算部分。它们是使用 Java Microbenchmark Harness (JMH) 实现的,并且在许多 Java 虚拟机 (JVM) 分支中运行并进行了充分的预热。这让我们对结果充满信心。事实上,这些数字的误差幅度仅为±2%。

以下是 Java 21 与 Java 17 上的约束流性能:

大多数情况下,切换到 Java 21 时性能都会略有提高。“Conference Scheduling”基准测试是唯一的异常值,通过对求解器进行一些额外的工作,我们很可能也会提高该基准测试的性能。

应该注意的是,我们使用 ParallelGC 作为垃圾收集器 (GC) 运行这些基准测试,而不是默认的 G1GC。在这篇文章的后面,我们将解释原因。

现实世界的基准

现在我们已经看到了微基准,是时候将它们与现实世界的求解器性能进行比较了。这包括整个求解器,而不仅仅是分数计算部分。

我们在 10 个不同的 JVM 分支中手动运行求解器,并使用中值计算速度。我们选择了可用基准的子集,以保持较短的运行时间;就所使用的启发法和所执行的代码路径而言,该选择代表了整个基准测试套件。再次使用ParallelGC作为垃圾收集器。结果如下:

这里没有什么惊喜。我们看到全面的性能小幅提升,证实了微基准测试的结果。与微基准相比,“Conference Scheduling”不再被视为异常值,这很有趣,并将作为我们调查可能的回归的另一个数据点。

由于我们尚未为这些大型基准建立正式的置信区间,因此我们无法肯定地说这些改进在统计上具有显性。 然而,运行之间观察到的波动足够小,因此足以让我们对结果充满信心。

为什么使用 ParallelGC ?

在我们使用 Timefold Solver 及其前身 OptaPlanner 的这些年里,我们发现 ParallelGC 是该求解器的最佳垃圾收集器。这应该不足为奇 - ParallelGC 是为高吞吐量而定制的,并且求解器是 100% CPU 限制的。相反,G1GC(默认垃圾收集器)是为低延迟量身定制的,这会产生相当大的差异。然而,事情会发生变化,我们有时需要挑战我们的假设。ParallelGC 仍然是求解器的最佳 GC 吗?

下图展示了G1GC(基线)和ParallelGC之间的性能差异。由于 Java 21 引入了分代 ZGC,这是另一种旨在低延迟的 GC,我们认为将其也包含在内也会很有趣。

结果(通过之前的微基准测试获得)很清楚:

  • ParallelGC 仍然是求解器的最佳 GC。

  • G1GC 位居第二,但速度要慢得多。

  • ZGC 是三者中迄今为止最差的。

如果我们增加 JVM 可用的堆大小,情况可能会改变,因为 ParallelGC 不能很好地扩展大堆,使用 -Xmx1G 时,它是明显的赢家。

结论

在这篇文章中,我们展示了:

  • Timefold Solver 1.1.0 与 Java 21 完美配合,无需任何更改。

  • 切换到 Java 21 可能会给您的 Timefold Solver 应用程序带来微小的性能改进,但您的效果可能会略有不同。

  • ParallelGC 仍然是求解器的最佳垃圾收集器。

我们鼓励您尝试 Java 21 并进行切换。毕竟它是免费的,你将能够享受最新、最好的 Java 平台。


相关推荐

Python操作Word文档神器:python-docx库从入门到精通

Python操作Word文档神器:python-docx库从入门到精通动动小手,点击关注...

Python 函数调用从入门到精通:超详细定义解析与实战指南 附案例

一、函数基础:定义与调用的核心逻辑定义:函数是将重复或相关的代码块封装成可复用的单元,通过函数名和参数实现特定功能。它是Python模块化编程的基础,能提高代码复用性和可读性。定义语法:...

等这么长时间Python背记手册终于来了,入门到精通(视频400集)

本文毫无套路!真诚分享!前言:无论是学习任何一门语言,基础知识一定要扎实,基础功非常的重要,找一个有丰富编程经验的老师或者师兄带着你会少走很多弯路,你的进步速度也会快很多,无论我们学习的目的是什么,...

图解Python编程:从入门到精通系列教程(附全套速查表)

引言本系列教程展开讲解Python编程语言,Python是一门开源免费、通用型的脚本编程语言,它上手简单,功能强大,它也是互联网最热门的编程语言之一。Python生态丰富,库(模块)极其丰富,这使...

Python入门教程(非常详细)从零基础入门到精通,看完这一篇就够

本书是Python经典实例解析,采用基于实例的方法编写,每个实例都会解决具体的问题和难题。主要内容有:数字、字符串和元组,语句与语法,函数定义,列表、集、字典,用户输入和输出等内置数据结构,类和对象,...

Python函数全解析:从入门到精通,一文搞定!

1.为什么要用函数?函数的作用:封装代码,提高复用性,减少重复,提高可读性。...

Python中的单例模式:从入门到精通

Python中的单例模式:从入门到精通引言单例模式是一种常用的软件设计模式,它保证了一个类只有一个实例,并提供一个全局访问点。这种模式通常用于那些需要频繁创建和销毁的对象,比如日志对象、线程池、缓存等...

【Python王者归来】手把手教你,Python从入门到精通!

用800个程序实例、5万行代码手把手教你,Python从入门到精通!...

Python从零基础入门到精通:一个月就够了

如果想从零基础到入门,能够全职学习(自学),那么一个月足够了。...

Python 从入门到精通:一个月就够了

要知道,一个月是一段很长的时间。如果每天坚持用6-7小时来做一件事,你会有意想不到的收获。作为初学者,第一个月的月目标应该是这样的:熟悉基本概念(变量,条件,列表,循环,函数)练习超过30个编...

Python零基础到精通,这8个入门技巧让你少走弯路,7天速通编程!

Python学习就像玩积木,从最基础的块开始,一步步搭建出复杂的作品。我记得刚开始学Python时也是一头雾水,走了不少弯路。现在回头看,其实掌握几个核心概念,就能快速入门这门编程语言。来聊聊怎么用最...

神仙级python入门教程(非常详细),从0到精通,从看这篇开始!

python入门虽然简单,很多新手依然卡在基础安装阶段,大部分教程对一些基础内容都是一带而过,好多新手朋友,对一些基础知识常常一知半解,需要在网上查询很久。...

Python类从入门到精通,一篇就够!

一、Python类是什么?大家在生活中应该都见过汽车吧,每一辆真实存在、能在路上跑的汽车,都可以看作是一个“对象”。那这些汽车是怎么生产出来的呢?其实,在生产之前,汽车公司都会先设计一个详细的蓝图...

学习Python从入门到精通:30天足够了,这才是python基础的天花板

当年2w买的全套python教程用不着了,现在送给有缘人,不要钱,一个月教你从入门到精通1、本套视频共487集,本套视频共分4季...

30天Python 入门到精通(3天学会python)

以下是一个为期30天的Python入门到精通学习课程,专为零基础新手设计。课程从基础语法开始,逐步深入到面向对象编程、数据处理,最后实现运行简单的大语言模型(如基于HuggingFace...

取消回复欢迎 发表评论: