ArchSummit 全球架构师峰会杭州倒计时10天,速来围观! 了解详情
写点什么

JDK 19 最新动态和 JDK 20 新特性预测

  • 2022 年 9 月 17 日
    北京
  • 本文字数:2476 字

    阅读完需:约 8 分钟

JDK 19最新动态和JDK 20 新特性预测

甲骨文 Java 平台组首席架构师 Mark Reinhold 宣布 JDK 19(JDK 17 之后的第二个非 LTS 版本)已经进入初始发布候选阶段。主线源代码库(2022 年 6 月初分叉到 JDK 稳定代码库)定义了 JDK 19 的特性集。关键的 Bug(如回归或严重的功能问题)得到了解决,但必须通过 Fix-Request 流程批准。根据发布计划,JDK 19 将在 2022 年 9 月 20 日正式发布。


最后一组(7 个)新特性(以 JEP 的形式)可以分为三类——核心 Java 库、Java 规范和 Hotspot 编译器。


被归类为核心 Java 库的 4 个新特性是:



被归类为 Java 规范的 2 个新特性是:



最后,被归类到 Hotspot 编译器的一个新特性是:



我们将介绍这些新特性,以及涵盖了这些新特性的四个主要 Java 项目——AmberLoomPanamaValhalla。这些项目旨在孵化出一系列组件,并最终经过合并包含在 JDK 中。

Amber


JEP 405,即记录模式(预览),提议用记录模式来解构记录值。记录模式可以与类型模式一起使用,“支持强大的、声明式的和可组合的数据浏览和处理形式”。类型模式最近已通过 JEP 406(即 switch 的模式匹配(预览),在 JDK 17 中交付)和 JEP 420(即 switch 的模式匹配(第二次预览),在 JDK 18 中交付)被用在 switch 的 case 子句中。更多关于 JEP 405 的细节可以在 InfoQ 的报道中看到。


JEP 427,即 switch 的模式匹配(第三次预览),针对前两轮预览反馈进行了增强——JEP 406(即 switch 的模式匹配(预览),在 JDK 17 中交付)和 JEP 420(即 switch 的模式匹配(第二次预览),在 JDK 18 中交付)。JEP 420 以来的变更包括——保护模式被替换为 switch 块中的 when 子句;当选择器表达式的值为空时,模式 switch 的运行时语义与遗留 switch 的语义更为接近。

Loom


JEP 425,即虚拟线程(预览),向 Java 平台引入了虚拟线程。这是一种轻量级线程,极大地减少了编写、维护和观察高吞吐量并发应用程序的工作量。更多关于 JEP 425 的细节可以在 InfoQ 的报道和甲骨文 Java 平台组开发者布道师 José Paumard 的 JEP Café屏播中找到。


JEP 428,即结构化并发(孵化器),提议通过引入一个新的库来简化多线程编程,这个库将运行在不同线程中的多个任务视为单个工作单元。这可以简化错误处理和取消操作,提高可靠性,并增强可观察性。更多关于 JEP 428 的细节可以在 InfoQ 的报道中看到。

Panama


JEP 424,即外部函数和内存 API(预览),为 Java 应用程序引入一个 API,通过高效调用外部函数和安全访问不受 JVM 管理的外部内存来实现与 Java 运行时之外的代码和数据的互操作。这个 JEP 演化自 JEP 419(即外部函数和内存 API(第二轮孵化器),在 JDK 18 中交付)和 JEP 412(即外部函数和内存 API(孵化器),在 JDK 17 中交付),并针对 Java 社区的反馈进行了增强。


JEP 426,即 Vector API(第四轮孵化器),根据前三轮孵化的反馈进行了改进——JEP 417(即 Vector API(第三轮孵化器),在 JDK 18 中交付)、JEP 414(即 Vector API(第二轮孵化器),在 JDK 17 中交付),以及 JEP 338(即 Vector API(孵化器),在 JDK 16 中作为孵化器模块交付)。JEP 426 提议对 Vector API 进行增强,从 MemorySegment(JEP 424,即外部函数和内存 API(预览))加载或存储 Vector。

Hotspot 编译器


JEP 422,即 Linux/RISC-V 移植,提议将 JDK 移植到 Linux/RISC-V(一种免费、开源的 RISC 指令集架构)上。移植版本将支持模板解释器、C1 和 C2 JIT 编译器以及所有当前的主要垃圾回收器,包括 ZGC 和 Shenandoah。这个 JEP 的主要重点是将移植的内容集成到 JDK 主线代码库中。

JDK 20


JDK 20 预计于 2023 年 3 月发布 GA 版本,目前还没有相关的 JEP。但是,根据最近提交的 JEP 草案和后续 JEP,我们可以推测哪些 JEP 有可能被包含在 JDK 20 中。


JEP 429,即小范围本地变量(孵化器),提议在线程内部和线程之间共享不可变数据。这要优于线程局部变量,特别是在使用大量虚拟线程时。更多关于 JEP 429 的细节可以在 InfoQ 的报道中看到。


JEP 草案 8277163,即值对象(预览),提议创建值对象——指定实例行为的无标识值类。这个草案与 JEP 401(原语类(预览),仍处于候选状态)相关。


JEP 401,即原语类(预览),引入了由开发者声明的原语类——在前面提到的值对象(预览)JEP 草案中定义的特殊类型的值类——定义了新的原语类型。


JEP 草案 8273943,即字符串模板(预览),提议使用字符串模板来增强 Java 语言。字符串模板类似于字符串字面量,但包含了嵌入表达式,在运行时将合并到字符串模板中。


JEP 草案 8280836,即有序集合,提议引入“一组新的接口来表示集合概念,这些集合中的元素按照定义良好的顺序进行排列,作为集合的结构属性。”这是由于 Java 的 Collections Framework 缺乏定义良好的顺序和统一操作。


JEP 草案 8284289,即改进的异步获取调用跟踪的方法,提议定义一个有效的 API,用于从信号处理器中获取用于分析的异步调用跟踪信息。


JEP 草案 8283227,即JDK源结构,用于描述 JDK 源代码和 JDK 代码库中相关文件的总体布局和结构。这个 JEP 建议帮助开发者适应 JEP 201(在 JDK 9 中交付的模块化源代码)所描述的源代码结构。


JEP 草案 8280389,即ClassFile API,提议提供一个用于解析、生成和转换 Java 类文件的 API。这个 JEP 在一开始将作为 JDK 内部的 ASM(Java 字节码操作和分析框架)替代品,并计划将其作为公共 API 开放出来。甲骨文 Java 语言架构师 Brian Goetz 将 ASM 描述为“一个带有大量遗留包袱的旧代码库”,并讲解了这个草案将如何演变并最终取代 ASM。


JEP 草案 8278252,即JDK打包和安装指南,提议为 macOS、Linux 和 Windows 平台提供创建 JDK 安装程序的指南,以降低不同 JDK 提供程序安装 JDK 时发生冲突的风险。其目的是通过规范化安装目录名称、包名和其他可能导致冲突的安装程序元素,在安装 JDK 更新版本时提供更好的用户体验。


我们预计甲骨文将很快开始将这些 JEP 中的一些或其他 JEP 包含在 JDK 20 中。


原文链接

JDK 19 and JDK 20: What We Know So Far


相关阅读:

Java 近期新闻:JDK 19 进入 RDP2、Oracle 关键补丁更新、TornadoVM on M1、Grails CVE


2022 年 9 月 17 日 08:003312

评论 2 条评论

发布
用户头像
这翻译错了extend翻译为扩展。 而extent 可以翻译为小范围本地变量,或者翻译为更技术的栈桢(stack frame)变量。

即扩展本地变量(孵化器)

40 分钟前 · 陕西
回复
感谢勘误,已经修改。
刚刚 · 北京
回复
没有更多了
发现更多内容

《从0到1学习Flink》—— Flink 写入数据到 Kafka

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Mac 上搭建 Flink 1.6.0 环境并构建运行简单程序入门

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Data Source 介绍

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Flink 写入数据到 ElasticSearch

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Flink 项目如何运行?

zhisheng

大数据 flink 流计算

Flink 从0到1学习—— Flink 不可以连续 Split(分流)?

zhisheng

大数据 flink 流计算

【迁移】用Redlock构建Redis分布式锁【译】

罗琦

分布式锁

《从0到1学习Flink》—— Flink 配置文件详解

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— 如何自定义 Data Source ?

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— 介绍Flink中的Stream Windows

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Flink JobManager 高可用性配置

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— 你上传的 jar 包藏到哪里去了?

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Apache Flink 介绍

zhisheng

大数据 flink 流计算

勇攀监控高峰-EMonitor之根因分析

乒乓狂魔

监控 全链路监控 故障定位 根因分析 AIOPS

Flink 从0到1学习 —— 如何使用 Side Output 来分流?

zhisheng

大数据 flink 流计算

如果你想做汽车开发,请先看看这篇。

水滴

自动驾驶 软件开发 开发

Deno会在短期内取代Node吗?

葡萄城技术团队

node.js SpreadJS deno

你不知道的JSON.stringify(上)

前端黑板报

Java json

【迁移】撸论文系列之——Bigtable

罗琦

论文阅读 bigtable

【迁移】读完了GFS论文之后的感悟

罗琦

大数据 GFS 论文阅读

《从0到1学习Flink》—— Flink 读取 Kafka 数据批量写入到 MySQL

zhisheng

大数据 flink 流计算

【迁移】Flink vs Spark

罗琦

大数据 flink spark

《从0到1学习Flink》—— Data Sink 介绍

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Flink Data transformation(转换)

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Flink 中几种 Time 详解

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Flink parallelism 和 Slot 介绍

zhisheng

大数据 flink 流计算

Flink 从0到1学习—— 分享四本 Flink 国外的书和二十多篇 Paper 论文

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— 如何自定义 Data Sink ?

zhisheng

大数据 flink 流计算

《从0到1学习Flink》—— Flink 读取 Kafka 数据写入到 RabbitMQ

zhisheng

大数据 flink 流计算

重学 Java 设计模式:实战工厂方法模式

小傅哥

设计模式 小傅哥 重构 架构设计 工厂模式

聊一聊采访外籍人员时需要注意的几点事项

李冬梅

态度 体验 感悟

自研数据库技术破局与最佳实践 | DBTalk 技术公开课第3期

自研数据库技术破局与最佳实践 | DBTalk 技术公开课第3期

JDK 19最新动态和JDK 20 新特性预测_语言 & 开发_Michael Redlich_InfoQ精选文章