写点什么

Java 22 正式发布

  • 2024-03-21
    北京
  • 本文字数:5060 字

    阅读完需:约 17 分钟

大小:2.54M时长:14:46
Java 22正式发布

本周,Oracle 发布了 JDK 22,包含 12 项新特性,可以分为四类,即核心 Java 库Java 语言规范HotSpot Java 工具。该公司还热衷于吸引新开发人员的关注,部分方法是改进对 Visual Studio Code (VS Code) 的支持。

 

JDK 22 是一个特性版本,这意味着 Oracle 将为其提供 6 个月的支持,直到下一个特性版本发布。LTS 版本(例如 JDK 21)则可获得长达 8 年的支持。下一个 LTS 版本将是 Java 25,计划于 2025 年 9 月发布。

 

Oracle 宣称 Java 是“当今科技趋势的排名第一语言”,并且它是“排名第一的企业/IT 组织使用语言”。 据 Oracle 称,目前有 630 亿个活跃的 Java 虚拟机 (JVM) 和 410 亿个基于云的 JVM 正在使用。

 

这些新特性中,有六个新特性归类在核心 Java 库下:

 

四个新特性归类在 Java 语言规范下:

 

一个新特性归类在 HotSpot 下:

 

最后,还有一个新特性归类在 Java 工具下:

 

我们对其中的一些新特性进行研究,并将其归类到四个主要的 Java 项目中,即AmberLoomPanamaValhalla,这些项目旨在通过精巧的合并,孵化一系列组件,以便最终将其纳入到 JDK 中。

Amber 项目

JEP 463,隐式声明类和实例主方法(Implicitly Declared Classes and Instance Main Methods,第二轮预览),以前被称为未命名类和实例主方法(Unnamed Classes and Instance Main Methods,预览)灵活主方法和匿名主类(Flexible Main Methods and Anonymous Main Classes,预览)隐式类和增强的主方法(Implicit Classes and Enhanced Main Methods,预览),该 JEP 包含了对前一轮预览反馈的增强,即 JEP 445,未命名类和实例主方法(预览)。这个 JEP 建议“演进 Java 语言,这样学生们就可以编写他们的第一个程序,而不需要理解为大型程序所设计的语言特性”。这篇 JEP 延续了甲骨文的 Java 语言架构师Brian Goetz在 2022 年 9 月发表的博客文章Paving the on-ramp。甲骨文的技术顾问Gavin Bierman已经发布了规范文档的初稿,供 Java 社区审查。关于 JEP 445 的更多细节可以在 InfoQ 的新闻报道中找到。

 


JEP 459,字符串模板(String Templates,第二轮预览),提供了对第一轮预览的再次预览,即 JDK 21 交付的 JEP 430, 字符串模板(String Templates,预览)。这个特性通过字符串模板对 Java 编程语言进行了增强,字符串模板是包含嵌入式表达式的字符串常量,可以在运行时进行解释,嵌入的表达式将在运行时进行计算和校验。关于 JEP 430 的更多详细信息可以参见 InfoQ 的新闻报道

 

JEP 456,未命名变量和模式(Unnamed Variables & Patterns),建议在上一轮的预览后最终确定该特性,即 JDK 21 交付的 JEP 443, 未命名模式和变量(Unnamed Patterns and Variables,预览)。这个特性建议“用未命名的模未命名变量来增强语言,前者与记录组件相匹配,但无需说明组件的名称和类型,后者可以被初始化但不使用”。 这两者均由下划线字符表示,如r instanceof _(int x, int y)r instanceof _

 

JEP 447,super(...)前导语句(Statements before super(...),预览),该 JEP 建议允许构造函数中不引用正在创建的实例的语句出现在this()super()调用之前,并保留现有的安全性和初始化保证。Bierman 提供了该特性的初始规范,供 Java 社区评审和反馈。

 

Loom 项目

JEP 464,作用域值(Scoped Values,第二次预览),以前被称为范围局部变量(Extent-Local Variables,孵化),这个 JEP 建议在 JDK 22 中进行第二轮预览,不做任何更改,以便于从上一轮预览中获得额外的经验和反馈,即 JDK 21 交付的 JEP 446, 作用域值(预览)和 JDK 20 交付的作用域值(孵化)。该特性允许在线程内部和线程之间共享不可变数据。这种方式优于 thread-local 变量,特别是在使用大量虚拟线程的时候。

 

JEP 462,结构化并发(Structured Concurrency,第二次预览),这个 JEP 将提议进行第二轮预览,不做任何变更,以便于从上一轮预览中获取更多的反馈,即 JDK 21 交付的 JEP 453,结构化并发(Structured Concurrency预览)。这个特性通过引入结构化并发性来简化并发编程,“将在不同线程中运行的相关任务组视为单个工作单元,从而简化错误处理和取消,提高可靠性并增强可观测性。”

Panama 项目

JEP 460,Vector API(第七轮孵化),吸收了对前六轮孵化反馈的改进,即 JDK 21 交付的 JEP 448,Vector API (第六轮孵化)、JDK 20 交付的 JEP 438,Vector API (第五轮孵化)、JDK 19 交付的 JEP 426,Vector API (第四轮孵化)、JDK 18 交付的 JEP 417,Vector API (第三轮孵化)、JDK 17 交付的 JEP 414,Vector API (第二轮孵化)以及在 JDK 16 中以孵化器模块交付的 JEP 338,Vector API(孵化)。JEP 448 最重要的变更包括对JVM编译器接口(JVM Compiler Interface,JVMCI)的增强,以支持 Vector API 值。

 

JEP 454,外部函数和内存API(Foreign Function & Memory API),建议在经历了两轮孵化和三轮预览之后确定该特性,即 JDK 17 中交付的 JEP 412, 外部函数和内存API(Foreign Function & Memory API,孵化器)、JDK 18 中交付的 JEP 419,外部函数和内存API(Foreign Function & Memory API,第二轮孵化)、JDK 19 中交付的 JEP 424,外部函数和内存API(Foreign Function & Memory API,预览)、JDK 20 中交付的 JEP 434,外部函数和内存API(Foreign Function & Memory API,第二轮预览)和 JDK 21 中交付的 JEP 442,外部函数和内存API(Foreign Function & Memory API,第三轮预览)。自上一个版本以来的改进包括:新的Enable-Native-Access manifest 属性,允许可执行 JAR 包中的代码调用受限制的方法而无需使用--enable-native-access标志;允许客户端通过编程的方式构建 C 函数描述符,避免使用特定于平台的常量;改进了对本地内存中可变长度数组的支持;支持多字符集本地字符串。关于 JEP 454 的更多细节请参见 InfoQ 的新闻报道

JDK 23

JDK 23计划于 2024 年 9 月正式发布,目前只有一个 JEP 列入了目标之中。不过,根据一些候选和草案 JEP,尤其是那些已提交的 JEP,我们可以推测还有哪些 JEP 可能被纳入 JDK 23。

 

JEP 455,模式、instanceof和switch中的原始类型(Primitive Types in Patterns, instanceof, and switch,预览)已经成为 JDK 23 的 Targeted 状态。 该 JEP 位于 Amber 项目下,建议通过允许在所有模式上下文中使用原始类型来增强模式匹配,并扩展instanceofswitch以允许使用原始类型。甲骨文公司的核心技术人员Aggelos Biboudis 最近发布了该功能的最新规范草案

 

JEP 468,派生记录创建(Derived Record Creation,预览),已经从 JDK Draft 8321133提升到了 Candidate 状态。该 JEP 建议通过派生创建记录来增强 Java 语言。由于记录是不可变的对象,开发人员经常会根据旧记录创建新记录,以建立新数据模型。派生创建可从现有记录派生出新记录,只需指定不同的组件即可,从而简化代码编写。

 

JEP 467,Markdown文档注释(Markdown Documentation Comments),已经从 JDK Draft 8316039提升到了 Candidate 状态。该特性建议支持 JavaDoc 文档注释以 Markdown 格式编写,而不仅仅是 HTML 和 JavaDoc @标记的混合体。这将使文档注释更易于编写,也更易于以源代码形式阅读。

 

JEP 466,类文件API(Class-File API,第二轮预览),已经从 JEP Draft 8324965 状态提升到了 Candidate 状态。该 JEP 建议进行第二轮的预览,以便于获取上一轮预览的反馈,也就是 JDK 22 即将交付的 JEP 457,类文件API(Class-File API,预览)。该特性提供了一个 API 来解析、生成和转换 Java 类文件。它最初作为 JDK 中ASM的替代品,ASM 是一个 Java 字节码操作和分析框架,并计划将其作为公开 API 对外开放。甲骨文的 Java 语言架构师Brian Goetz将 ASM 描述为“带有大量遗留包袱的旧代码库”,并提供了关于该草案如何发展并最终取代 ASM 的背景信息

 

JEP 465,字符串模板(String Templates),已经从 JEP Draft 8323333 状态提升到了 Candidate 状态。该 JEP 建议在两轮的预览之后最终确定该特性,也就是 JDK 22 即将交付的 JEP 459,字符串模板(String Templates,第二轮预览)和 JDK 21 交付的 JEP 430,字符串模板(String Templates,预览)。这个特性通过字符串模板对 Java 编程语言进行了增强,字符串模板是包含嵌入式表达式的字符串常量,可以在运行时进行解释,嵌入的表达式将在运行时进行计算和校验。关于 JEP 430 的更多详细信息可以参见 InfoQ 的新闻报道

 

JEP 401,Null-Restricted值对象存储(Null-Restricted Value Object Storage,预览),以前被称为原始类(Primitive Classes,预览),位于 Valhalla 项目中,它引入了开发人员声明的原始类(Primitive Classes),即由值对象 API 定义(Value Objects API)的特殊类型的值类,它们定义了新的原始类型。

 

甲骨文的 Java 架构师Paul Sandoz提交了 JEP Draft 8326878Vector API(孵化器)。经历了从 JDK 16 到 JDK 22 的七轮孵化后,本 JEP 建议在 JDK 23 中重新孵化 API,与 JDK 22 相比,不会对 API 进行更改,也不对实现进行实质性的变更。该特性将引入一个 API,用于“表达向量计算,这些计算可在运行时可靠地编译为所支持 CPU 架构上的最佳向量指令,从而实现优于同等标量计算的性能”。

 

Bierman 和 PatientEXP 的创始人兼 CEOArchie Cobbs提出了 JEP Draft 8325803灵活的构造函数方法体(Flexible Constructor Bodies,第二轮预览),该 JEP 建议进行第二轮预览并更改名称,以获取对上一轮预览的反馈,也就是 JDK 22 即将交付的 JEP 447:super(...)前导语句(Statements before super(...),预览)。该特性允许构造函数中不引用正在创建的实例的语句出现在this()super()调用之前,并保留现有的安全性和初始化保证。该 JEP 中的变更包括:对本地类的处理;将在显式构造函数调用前不能访问字段的限制进行了放宽,即在显式构造函数调用前不能读取字段的要求。Bierman 提供了该特性的初始规范,供 Java 社区评审和反馈。

 

JEP Draft 8307341准备限制对JNI的使用(Prepare to Restrict The Use of JNI),建议限制使用本质上不安全的 Java 本地接口(Java Native Interface,JNI),同时在外部函数和内存 (Foreign Function & Memory,FFM)API 中使用受限方法,该 API预计将在JDK 23中成为最终特性。从 JDK 23 开始,除非 FFM 用户在命令行上启用了不安全的本地访问,否则 Java 运行时将显示关于使用 JNI 的警告。预计在 JDK 23 之后的版本中,使用 JNI 将抛出异常而非警告。

 

JEP Draft 8313278Java虚拟机的预先编译(Ahead of Time Compilation for the Java Virtual Machine),建议“增强 Java 虚拟机加载编译为原生代码的 Java 应用程序和库的能力,以加快启动和基线执行”。

 

JEP Draft 8312611已计算常量(Computed Constants,预览),引入了已计算常量的概念,它被定义为最多初始化一次的不可变值持有者。它具有final字段在性能和安全性方面的优势,同时在初始化时机方面具有更大的灵活性。该功能将作为预览API 首次亮相。

 

JEP Draft 8283227JDK源码结构(JDK Source Structure),这是一个信息型的 JEP,描述了 JDK 源代码的整体布局和结构以及 JDK 仓库中的相关文件。该 JEP 建议帮助开发人员适应 JDK 9 中交付的 JEP 201,Modular Source Code(模块化源代码)所描述的源代码结构。

 

JEP Draft 8278252JDK打包和安装指南(JDK Packaging and Installation Guidelines),这是一个信息型的 JEP,建议提供在 macOS、Linux 和 Windows 上创建 JDK 安装程序的指南,以降低不同 JDK 提供商之间安装 JDK 发生冲突的风险。其目的是通过规范安装目录名称、软件包名称和安装程序中可能导致冲突的其他元素,使得在安装 JDK 更新版本时获得更好的体验。

 

我们预计甲骨文将很快开始为 JDK 23 制定更多 JEP。

 

参考链接:

https://www.infoq.com/news/2024/03/java-22-so-far/

https://www.theregister.com/2024/03/19/catch_java_22_now_available/

2024-03-21 17:056595

评论

发布
暂无评论
发现更多内容

Spinner: Pinterest的工作流平台

俞凡

架构 工作流引擎 大厂实践 Pinterest

CDH/HDP迁移之路

星环科技

模块二:作业微信朋友圈的高性能复杂度

本人法海

「架构实战营」

《数据密集型型系统设计》LSM-Tree VS BTree

懒时小窝

哈希 B-tree 列式存储 LSM-Tree

探索SeekTiger生态,Tiger DAO VC有哪些新期待

小哈区块

图数据库渐成技术新风口,星环科技自研图数据库领跑新赛道

星环科技

阿里云与达摩院合作 AHPA 弹性预测论文被顶会 ICDE 录用

阿里巴巴云原生

“卷王”英伟达的真面目

脑极体

好身体,从增加睡眠时间开始

石云升

睡眠 4月月更

白话大数据 | 关于图数据库,没有比这篇更通俗易懂的啦

星环科技

XX物流同城快递架构设计文档

Steven

李智慧 高并发架构实战课

Linux之lastlog命令

入门小站

Linux

在线XML美化格式化工具

入门小站

工具

用JAVA捋一下设计模式1-简单工厂模式

下雨了

设计模式 简单工厂模式 4月月更

【PIMF】《伟大的计算原理》提炼“六脉神剑”认识OpenHarmony技术路线

离北况归

《伟大的计算原理》 技术路线 IMF

DDD实战(7):战术设计、整体流程与首次冲刺

深清秋

DDD 软件架构设计 生鲜电商系统

Sophon 3.0全面升级,你准备好拥抱进阶版本的ML建模平台了吗?

星环科技

开源IM项目OpenIM每周迭代版本发布-群管理 阅后即焚等-v2.0.6

Geek_1ef48b

PlatoFarm空投社区的逻辑,效仿无聊猿还是Dao理念使然

小哈区块

用JAVA捋一下设计模式3-抽象工厂模式

下雨了

设计模式 抽象工厂模式 4月月更

用JAVA捋一下设计模式 4-单例模式

下雨了

设计模式 单例模式 4月月更

用JAVA捋一下设计模式23-解释器模式

下雨了

设计模式 4月月更 解释器模式

Rust中值销毁前的清理动作

Shine

rust

用JAVA捋一下设计模式2-工厂方法模式

下雨了

设计模式 工厂方法模式 4月月更

在线条码生成器

入门小站

工具

【限时免费】阿里云 ACR EE 增强型扫描引擎限时体验中,多维度保障容器镜像安全

阿里巴巴云原生

Kubernetes官方java客户端之六:OpenAPI基本操作

程序员欣宸

4月月更

Linux驱动开发-proc接口介绍

DS小龙哥

4月月更

业务流程驱动的数字化转型,中小微企业开启转型的最简单方法论

王吉伟频道

RPA 数字化转型 机器人流程自动化 业务流程自动化

Java 22正式发布_编程语言_Michael Redlich_InfoQ精选文章