Java 22版本全新上线

发表时间: 2024-03-27 18:00

作者 | Michael Redlich

译者 | 张卫滨

策划 | Tina

本周,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 库下:

  • JEP 454:外部函数和内存API(Foreign Function & Memory API)
  • JEP 457:类文件API(Class-File API,预览)
  • JEP 460:向量API(Vector API,第七轮孵化)
  • JEP 461:流聚合器(Stream Gatherers,预览)
  • JEP 462:结构化并发(Structured Concurrency,第二轮预览)
  • JEP 464:作用域值(Scoped Values,第二轮预览)


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

  • JEP 447:super(...)前导语句(Statements before super(...),预览)
  • JEP 456:未命名变量和模式(Unnamed Variables & Patterns)
  • JEP 459:字符串模板(String Templates,第二轮预览)
  • JEP 463:隐式声明类和实例主方法(Implicitly Declared Classes and Instance Main Methods,第二轮预览)


一个新特性归类在 HotSpot 下:

  • JEP 423:G1的区域锚定(Region Pinning for G1)


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

  • JEP 458:启动多文件源码程序(Launch Multi-File Source-Code Programs)


我们对其中的一些新特性进行研究,并将其归类到四个主要的 Java 项目中,即Amber、Loom、Panama和Valhalla,这些项目旨在通过精巧的合并,孵化一系列组件,以便最终将其纳入到 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 8326878,Vector 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 8313278,Java虚拟机的预先编译(Ahead of Time Compilation for the Java Virtual Machine),建议“增强 Java 虚拟机加载编译为原生代码的 Java 应用程序和库的能力,以加快启动和基线执行”。


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


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


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


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

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