JDK 17 是 Java 发展历程中一个非常重要的长期支持(LTS)版本,它于 2021 年 9 月发布,接替了 JDK 11,并提供了数年的支持23。
对于开发者来说,升级到 JDK 17 最直观的感受是代码变得更简洁、运行速度更快以及安全性更高。
以下我为你整理的 JDK 17 核心新特性,分为语言、API、性能和移除/弃用三个维度:
核心语言特性
JDK 17 引入了一些非常实用的语法糖,能显著减少模板代码
密封类(Sealed Classes)------正式版
- 作用: 限制类或接口的继承。以前我们只能用
final完全禁止继承,或者不加限制。现在我们可以精确指定"只允许 A、B、C 这几个类继承我"。 - 场景: 定义严格的领域模型或代数数据类型。
- 代码示意:
java
// 只允许 Circle, Rectangle 继承
public sealed interface Shape permits Circle, Rectangle { }
final class Circle implements Shape { } // 子类必须声明为 final, sealed 或 non-sealed
final class Rectangle implements Shape { }
Switch 模式匹配(Pattern Matching for Switch)------预览版
- 作用: 增强了
switch语句,使其支持直接对类型进行匹配,并自动进行类型转换(解构)。 - 优势: 避免了写一堆
instanceof判断和强制转换,代码更清晰。 - 代码示意:
java
Object obj = ...;
switch (obj) {
case null -> System.out.println("空值");
case String s -> System.out.println("字符串: " + s.toUpperCase());
case Integer i -> System.out.println("数字: " + i * 2);
default -> System.out.println("未知类型");
}
instanceof 模式匹配
作用: 类似于 Switch 的改进,instanceof 也可以在判断类型的同时直接赋值给一个变量,无需再手动强转1011
文本块(Text Blocks)
作用: 使用三个双引号 """ 来定义多行字符串,再也不用写 \n 和 + 来拼接长字符串了,特别适合写 SQL 或 JSON8。
API 与库的增强
默认垃圾回收器(G1)
G1 GC 在大内存场景下表现更好,停顿时间更可控。JDK 17 进一步优化了 G1,例如默认启用并行 Full GC,以及在空闲时自动归还内存给操作系统(Uncommit),这对容器化部署(Docker/K8s)非常友好1113。
ZGC 和 Shenandoah
虽然这两个低延迟垃圾回收器在 JDK 11/12 左右就出现了,但在 JDK 17 中已经非常成熟。它们可以将 GC 停顿时间控制在 10ms 以内,适合对延迟极其敏感的服务13。
强封装 JDK 内部 API
默认情况下,JDK 内部的私有字段(如 sun.misc.Unsafe 以外的部分)被强封装,不能通过反射随意访问。这虽然可能会影响一些老旧的依赖库,但极大地提高了 Java 平台的安全性和可维护性56。
移除和弃用的功能
JDK 17 做了一些"减法",清理了过时的技术:
- 移除了 Applet API: Applet 已经是历史遗迹,正式被移除56。
- 移除了实验性的 AOT 和 JIT 编译器: 维护成本高且使用率低35。
- 弃用安全管理器: 计划在未来版本中移除,建议使用其他安全机制35。
JDK 8 vs JDK 17 关键对比
为了让你更直观地了解差异,我为你总结了这个对比表
| 特性维度 | JDK 8 (经典版) | JDK 17 (现代版) |
|---|---|---|
| 语法风格 | 冗长,大量样板代码 | 简洁,支持 var、record、sealed、text block |
| 垃圾回收 | 默认 Parallel/CMS (停顿较长) | 默认 G1 (低停顿),支持 ZGC (亚毫秒级) |
| 安全性 | 安全管理器为主 | 强封装内部 API,移除了安全管理器,反序列化过滤增强 |
| 模块化 | 无模块系统 | 拥有模块系统 (JPMS),可构建更轻量的运行时 |
| 适用场景 | 维护老项目 | 新项目、云原生、微服务、高性能应用 |
我的建议:
如果你还在使用 JDK 8,升级到 JDK 17 是一个非常值得的决定。它不仅在性能上(特别是内存占用和 GC 停顿)有显著升,而且现代的语法特性(如 record 和 sealed class)能让你写出更优雅、更不容易出错的代码。