开发软件

关注公众号 jb51net

关闭
Java SE Development Kit(JDK) 17 for Mac v17.0.18 苹果电脑版

Java SE Development Kit(JDK) 17 for Mac v17.0.18 苹果电脑版

您还可以选择:官方全版本下载

热门排行

简介

Java SE Development Kit(JDK) 17 for Mac v17.0.18 苹果电脑版

Java SE Development Kit 17(JDK/Java 17) 正式 GA已经发布,按照发布规划,JDK/Java 17 属于长期支持版本 (LTS),将会获得 8 年的技术支持,直至 2029 年 9 年。Java 17 LTS 是 Java SE 平台的最新长期支持版本。 根据 Oracle 免费条款和条件许可,JDK 17 二进制文件可在生产中免费使用,并可免费重新分发。至少在 2024 年 9 月之前,JDK 17 将根据这些条款接收更新。

Java SE Development Kit 17 for Windows :点击下载

Java SE Development Kit 17 for Linux :点击下载

JDK 是使用 Java 编程语言构建应用程序和组件的开发环境。JDK 包括用于开发和测试用 Java 编程语言编写并在 Java 平台上运行的程序的工具。本次提供的是Java SE Development Kit(JDK) 17 for Mac官方版本下载,欢迎需要此款工具的朋友前来下载使用。

JDK/Java 17 总共包含 14 个 JEP,如下:

306: Restore Always-Strict Floating-Point Semantics
356: Enhanced Pseudo-Random Number Generators
382: New macOS Rendering Pipeline
391: macOS/AArch64 Port
398: Deprecate the Applet API for Removal
403: Strongly Encapsulate JDK Internals
406: Pattern Matching for switch (Preview)
407: Remove RMI Activation
409: Sealed Classes
410: Remove the Experimental AOT and JIT Compiler
411: Deprecate the Security Manager for Removal
412: Foreign Function & Memory API (Incubator)
414: Vector API (Second Incubator)
415: Context-Specific Deserialization Filters

功能特性

JDK 17 发行说明:https://www.oracle.com/java/technologies/javase/17-relnote-issues.html

Restore Always-Strict Floating-Point Semantics

恢复始终执行严格模式 (Always-Strict) 的浮点定义

Enhanced Pseudo-Random Number Generators

添加增强的伪随机数生成器

New macOS Rendering Pipeline

为 macOS 引入新渲染管道

macOS/AArch64 Port

支持将 JDK 移植到 macOS/AArch64 架构

Deprecate the Applet API for Removal

弃用待移除的 Applet API

Strongly Encapsulate JDK Internals

强封装的 JDK 内部 API,默认对 JDK 内部进行强封装

Pattern Matching for switch (Preview)

switch 模式匹配进入预览 (Preview) 阶段

Remove RMI Activation

移除 RMI(远程方法调用)激活机制

Sealed Classes

密封类和接口正式可用,用于限制哪些类和接口可以继承或实现它们。

Remove the Experimental AOT and JIT Compiler

移除实验性的 AOT 和 JIT 编译器

Deprecate the Security Manager for Removal

弃用待移除的安全管理器 (Security Manager)

Foreign Function & Memory API (Incubator)

外部函数和内存 API 进入孵化阶段,Java 应用程序通过该 API 能够与 Java 运行时之外的代码和数据进行互操作。

Vector API (Second Incubator)

在 JDK/Java 17 中,Vector API 已进入孵化的第二阶段,Vector API 用于表达可在支持的 CPU 架构上编译为最佳矢量硬件指令的矢量计算,以实现优于等效标量计算的性能。

Context-Specific Deserialization Filters

增加面向特定上下文的反序列化过滤器,此特性允许应用程序通过 JVM 的过滤器工厂配置特定于上下文和动态选择的反序列化过滤器。

值得一提的是,根据 Oracle 最新推出的「Free Java License」,Oracle JDK 可免费用于生产环境。

Free Java License 摘要

此外,Oracle 还提议将 JDK LTS 的发布周期从每三年一次改为每两年一次。如果该提案被接受,这意味着 JDK 17 之后的下一个 JDK LTS 版本将是 JDK 21,而不是 JDK 23。

JDK17新特性详解

预览版:该功能在当前版本可以使用,如果效果不是很好的话,可能以后的其他版本就会删去该功能。

最终版:该功能在之前版本效果很好,之后的每个版本中都会存在该功能。

1、switch新增模式(预览版)

使用 switch 表达式和语句的模式匹配以及对模式语言的扩展来增强 Java 编程语言。将模式匹配扩展到 switch 允许针对多个模式测试表达式,每个模式都有特定的操作,以便可以简洁安全地表达复杂的面向数据的查询。基于JDK16 instanceof模式匹配(最终版)优化升级switch使用方法,先回忆下JDK16模式匹配(最终版)

if (obj instanceof String s) {
// 直接使用 s拼接字符串
s += "heihei";
} else if (obj instanceof Integer i){
// 直接使用i进行整型逻辑运算
i += 1;
}

switch可直接用instanceof模式匹配选择(需要提前考虑null判断)

Object o;
switch (o) {
case null -> System.out.println("首先判断对象是否为空,走空指针逻辑等后续逻辑");
case String s -> System.out.println("判断是否为字符串,s:" + s);
case record p -> System.out.println("判断是否为Record类型: " + p.toString());
case int[] arr -> System.out.println("判断是否为数组,展示int数组的长度" + ia.length);
case Integer i -> System.out.println("判断是否为Intger对象,i:" + i);
case Student s -> System.out.println("判断是否为具体学生对象,student:" + s.toString());
case UserCommonService -> System.out.println("判断是否为普通用户实现类,然后走普通用户逻辑");
case UserVipService -> System.out.println("判断是否为vip用户实现类,然后走vip用户逻辑");
default -> System.out.println("Something else");
}

2、Realed class密封类(最终版)

密封类和接口限制哪些其他类或接口可以扩展或实现它们。

public sealed interface Shape{
final class Planet implements Shape {}
final class Star implements Shape {}
final class Comet implements Shape {}
}
public abstract sealed class Test{
final class A extends Test {}
final class B extends Test {}
final class C extends Test {}
}

3、随机数增强

为伪随机数生成器 (PRNG) 提供新的接口类型和实现,包括可跳转的 PRNG 和额外的一类可拆分 PRNG 算法 (LXM)。

4、浮点运算更加严格

简化数字敏感库开发,包括java.lang.Math和java.lang.StrictMath(对开发无实际意义)

5、Parallel GC 默认启用

Parallel GC 默认启用自适应并行处理,并行GC确定java.lang.ref.Reference在垃圾收集期间用于处理实例的最佳线程数。

默认-XX:ParallelRedProcEnabled: true。在有多个线程可用于垃圾收集的机器上,明显改善了垃圾收集暂停的阶段,如果遇到垃圾收集暂停增加的情况,可以通过-XX:ParallelRedProcEnabled在命令行上指定到原始行为

6、增强TreeMap

增强JDK-8176894(TreeMap 没有对 putIfAbsent()、computeIfAbsent()、computeIfPresent()、compute() 方法的专门实现。默认实现经常导致两次树遍历,这会损害性能)

7、弃用Socket实现工厂机制

弃用并最终删除用于为java.net 包中的套接字类型静态配置系统范围工厂 的 API 点

具体如下:

* 方法:
static void ServerSocket.setSocketFactory (SocketImplFactory fac)
static void Socket.setSocketImplFactory (SocketImplFactory fac)
static void DatagramSocket.setDatagramSocketImplFactory (DatagramSocketImplFactory fac)

* Types
java. net SocketImplFactory
java.net DatagramSocketImplFactory

也可以弃用java.net SocketImplFactory 和 DatagramSocketImplFactory 类型 ,因为它们的唯一用途与上述工厂有关 设置方法。

8、统一日志支持异步日志刷新

为了避免在使用统一日志的线程中出现不希望的延迟,用户现在可以请求统一日志系统以异步模式运行。通过传递命令行选项来完成的-Xlog:async。在异步日志模式下,日志站点将所有日志消息排入缓冲区。独立线程负责将它们刷新到相应的输出。中间缓冲区是有界的。缓冲区耗尽时,将丢弃排队消息。可以使用命令行选项控制中间缓冲区的大小-XX:AsyncLogBufferSize=<bytes>。

9、新增 java.time.InstantSource

java.time.InstantSource引入了一个新界面。这个接口是一个抽象java.time.Clock,只关注当前时刻,不涉及时区。

10、javadoc工具

新的“新 API”页面和改进的“弃用”页面,JavaDoc 现在可以生成一个页面,总结最近 API 的变化。要包含的最新版本列表是使用--since命令行选项指定的。这些值用于查找@since要包含在新页面上的具有匹配标签的声明。该--since-label命令行选项提供了“新API”页面的标题文本使用。

在 macOS 上安装 JDK

在 macOS 上安装 JDK:

.dmg从.tar.gz页面下载所需的 JDK或文件 :

macOS x64 系统: 或jdk-17.interim.update.patch_macos-x64_bin.dmgjdk-17.interim.update.patch_macos-x64_bin.tar.gz
macOS aarch64(64 位 ARM)系统: 或jdk-17.interim.update.patch_macos-aarch64_bin.dmgjdk-17.interim.update.patch_macos-aarch64_bin.tar.gz

单击接受许可协议。

从浏览器下载窗口或文件浏览器,双击.dmg文件以启动它。

出现一个Finder窗口,其中包含一个打开框的图标和.pkg文件名。

双击该图标以启动安装应用程序。JDK 17.pkg

安装应用程序显示简介窗口。

点击继续。

在安装类型窗口出现。

单击安装。

出现一个窗口,显示消息: 安装程序正在尝试安装新软件。输入您的密码以允许此操作。

输入管理员用户名和密码,然后单击安装软件。

安装软件并显示确认窗口。

安装软件后,如果要节省磁盘空间,可以删除.dmg 或 .tar.gz文件。

在 macOS 上卸载 JDK

在 macOS 上卸载 JDK:

您必须具有管理员权限。

笔记:不要试图通过从 中删除 Java 工具来卸载 Java /usr/bin。此目录是系统软件的一部分,Apple 将在您下次执行操作系统更新时重置任何更改。

去/Library/Java/JavaVirtualMachines。

rm以root用户身份执行命令或使用sudo工具删除名称与以下格式匹配的目录:

/Library/Java/JavaVirtualMachines/jdk-17.interim.update.patch.jdk

例如,要卸载17 Interim 0 Update 0 Patch 0:

$ rm -rf jdk-17.jdk

macOS 安装常见问题

本主题提供了有关在 macOS 计算机上安装 JDK 的以下常见问题解答。

1. 如何找出系统默认的Java版本?

当您从命令行运行 Java 应用程序时,它使用默认的 JDK。如果您不开发 Java 应用程序,那么您无需担心这一点。请参阅确定 macOS 上的默认 JDK 版本。

2. 安装 Java for macOS 2012-006 后,我可以继续使用 Apple 的 Java 6 和 macOS JDK for Java 17吗?

如果您想继续使用命令行使用 Java 6 进行开发,那么您可以为您喜欢的命令环境修改启动脚本。对于 bash,使用这个:

$ export JAVA_HOME=`/usr/libexec/java_home -v 17`

一些应用程序使用/usr/bin/java调用 Java。为 macOS 2012-006 安装 Java 后,/usr/bin/java将找到安装的最新 JDK,并将其用于/usr/bin. 您可能需要修改这些应用程序才能找到 Java 6,或者联系开发人员获取更新版本的应用程序。

4. Application Utilities 中的 Java Preferences 应用程序发生了什么变化?

Java Preferences 应用程序是 Apple Java 安装的一部分,Oracle Java 不使用它。因此,不包含 Apple Java 的 Apple macOS 版本将不包含 Java 首选项。

更新日志

Java™ SE Development Kit 17,更新 17.0.18(JDK 17.0.18)
2026年1月20日

本次更新的完整版本字符串为 17.0.18+8(“+” 表示“构建”)。版本号为 17.0.18。该 JDK 符合 Java SE 规范 17.1 版本(JSR 392 MR 1 2024-07-02)。

安全基线
JDK 17.0.18 发布时 Java 运行时的安全基线如下表所示:

Java 家族版本    安全基线(完整版本字符串)
17    17.0.18+8
11    11.0.30+7
8    1.8.0_481-b10

保持JDK的更新
Oracle 建议每次关键补丁更新时都要更新 JDK。 为了判断某个版本是否为最新,安全基线页面可以 用于确定每个发行家族的最新版本。

关键补丁更新包含安全漏洞修复,通常提前一年发布关键补丁更新、安全警报和公告。不建议在下一次关键补丁更新后使用该 JDK(版本17.0.18)。预计为2026年4月21日。

Java管理服务面向所有用户,可以帮助你在系统中发现易受攻击的Java版本。Java SE 订阅用户和运行在 Oracle Cloud 中的客户可以使用 Java 管理服务更新 Java 运行时,并进行进一步的安全审查,比如识别 Java 程序中使用的潜在易受攻击的第三方库。现有的 Java 管理服务用户,点击这里登录您的仪表盘。Java 管理服务文档提供了一份对所有人开放的功能列表,以及仅对客户开放的功能。了解更多关于使用 Java 管理服务来监控和保护您的 Java 安装的信息。

新功能

core-libs/java.rmi
➜ 默认启用端点识别,适用于TLS上的RMI连接 (JDK-8341496(非公开))
如果使用该类,RMI会使用TLS连接。这些连接现在默认启用了TLS端点识别。这可能导致一些之前正常工作的TLS连接出现故障。如果发生这种情况,确保服务器提供的证书具有与服务器主机名相匹配的主体替代名称。或者,客户端可以通过将系统属性设置为 来禁用 RMI TLS 连接的端点识别。javax.rmi.ssl.SslRMIClientSocketFactoryjdk.rmi.ssl.client.enableEndpointIdentificationfalse

其他注释

security-libs/javax.net.ssl
➜ 禁用了TLS 1.2和DTLS 1.2中的SHA-1握手签名 (JDK-8340321))
在TLS 1.2和DTLS 1.2握手签名中,SHA-1算法已被默认禁用,方法是在配置文件中添加安全属性。RFC 9155 弃用了 TLS 1.2 和 DTLS 1.2 数字签名中的 SHA-1。用户可自行承担风险,通过移除安全属性,重新启用 TLS 1.2 和 DTLS 1.2 握手签名中的 SHA-1 算法。"rsa_pkcs1_sha1 usage HandshakeSignature, ecdsa_sha1 usage HandshakeSignature, dsa_sha1 usage HandshakeSignature"jdk.tls.disabledAlgorithmsjava.security"rsa_pkcs1_sha1 usage HandshakeSignature, ecdsa_sha1 usage HandshakeSignature, dsa_sha1 usage HandshakeSignature"jdk.tls.disabledAlgorithms

安装/安装
➜ Windows 安装程序返回完整版本目录及交汇( JDK-8310932(非公开))
对于 JDK11+ LTS 系列,JDK 默认安装到特定版本的安装目录中。11+ 的安装目录在版本特定字符串前会有一个 - ,以保持与各家族过去 11+ 惯例的一致性。在“最新”目录中也会创建一个连接,Windows中也称为符号链接。它会指向该家族的最新版本。以下是安装和交汇点11+家族的详细示例:

版本    安装目录    交汇位置
jdk25.0.2    C:\Program Files\Java\jdk-25.0.2    C:\Program Files\Java\latest\jdk-25
JDK17.0.18    C:\Program Files\Java\jdk-17.0.18    C:\Program Files\Java\latest\jdk-17
jdk11.0.30    C:\Program Files\Java\jdk-11.0.30    C:\Program Files\Java\latest\jdk-11
每个交汇点始终指向匹配LTS家族中最新的JDK。当匹配LTS家族的最后一个JDK卸载时,每个家族的连接将被移除。

安装/安装
➜ 让jcmd命令在无头JDK RPM中可用 (JDK-8359443(非公开))
jcmd命令将以无头JDK RPM代替头头JDK RPM使用。

它将被加入替代组,而非替代方案组。javajavac

security-libs/javax.net.ssl
➜ 废TLS_RSA密码套件 (JDK-8245545)
TLS_RSA密码套件默认被禁用,方法是在java.security配置文件中的jdk.tls.disabledAlgorithms安全属性中添加“TLS_RSA_”。TLS_RSA密码套件不维护前向保密性,且不常用。一些TLS_RSA密码套件已经被禁用,因为它们使用了DES、3DES、RC4或NULL,这些都是被禁用的。此举会禁用所有剩余TLS_RSA密码套件。任何尝试使用以“TLS_RSA_”开头的密码套件都会因SSLHandshakeException而失败。用户可自行承担风险,通过从安全属性中移除“TLS_RSA_”来重新启用这些密码套件。以下先前启用的密码套件现已禁用:jdk.tls.disabledAlgorithms

TLS_RSA_WITH_AES_256_GCM_SHA384

TLS_RSA_WITH_AES_128_GCM_SHA256
TLS_RSA_WITH_AES_256_CBC_SHA256
TLS_RSA_WITH_AES_128_CBC_SHA256
TLS_RSA_WITH_AES_256_CBC_SHA
TLS_RSA_WITH_AES_128_CBC_SHA

core-libs/java.util:i18n
➜ 基于Debian的Linux(JDK-8345213)中默认时区检测的变 更)
在基于 Debian 的 Linux 发行版如 Ubuntu 上,该文件曾用于确定 JDK 的默认时区()。根据Debian的维基,现在是系统默认时区的主要来源,因此变得多余。因此,JDK的默认时区检测逻辑已更新为使用。如果和因任何原因不一致,JDK的默认时区现仅基于档案确定。/etc/timezoneTimeZone.getDefault()/etc/localtime/etc/timezone/etc/localtime/etc/timezone/etc/localtime/etc/timezone/etc/localtime

security-libs/java.security
➜ 证书权威信息访问扩展 (JDK-8368032(非公开))中URI的过滤规则
引入了一个新的系统和安全属性,, ,该属性允许用户定义一个或多个过滤规则,应用于X.509证书上权威信息访问扩展获得的URI。这些过滤规则专门应用于CA发行机构的访问方式。任何CA发行者在X.509证书中的URI只有在系统属性被启用且过滤器允许该URI时才会被跟踪。com.sun.security.allowedAIALocationscom.sun.security.enableAIAcaIssuers

为了设置规则,用户必须以同名设置安全属性或系统属性。如果系统属性有值,它会覆盖安全属性。默认情况下,该属性为空,这会执行一个拒绝所有规则集。com.sun.security.allowedAIALocations

对于任一性质,取值由一组空间分离规则组成,这些规则以URI的形式出现,具有以下约束条件:

URI必须是绝对且层级分明的。
URI只能使用以下方案之一:http、https、ldap或ftp(不区分大小写)。
必须指定主机名或地址,并且必须匹配(不区分大小写)。主机名不进行名称解析以匹配URI与IP地址。
端口号必须匹配。如果省略了端口号,则在比较中使用已知端口。
对于分层方案(http[s], ftp):
规则中URI中归一化路径部分以大小写区分方式匹配。如果最后一个组件不以斜杠(/)结尾,则视为文件路径,必须与CA发行器URI路径组件匹配。如果规则的路径组件以斜杠结尾,则必须与CA发行器URI路径组件的前缀相匹配或为前缀。(例如,的滤波路径将匹配CA的发行者路径,且。)/ab/cd//ab/cd//ab/cd/ef/ab/cd/ef/ghi
匹配CA发行者URI时,查询字符串和片段将被忽略。
对于LDAP的URI:
基础DN必须完全匹配(不区分大小写)。
规则中的任何查询字符串(如果指定)将被忽略。
对于属性,单个值为“任意”(大小写不区分)将生成一个允许所有规则。

漏洞修复

本版本还包含了 Oracle 关键补丁更新中描述的安全漏洞修复。

➜ 17.0.18 修复的问题:

#    JBS    组成部分    摘要
1    JDK-8292214    client-libs/2d    awt_GraphicsEnv.c:386 的 getAllConfigs 内存泄漏
2    JDK-8334509    client-libs/2d    取消 PageDialog 不会返回相同的 PageFormat 对象
3    JDK-8361748    client-libs/2d    对 XBM 映像大小设定限制
4    JDK-8286159    client-libs/java.awt    awt_GraphicsEnv.c:585 的 getAllConfigs 内存泄漏
5    JDK-8324491    client-libs/java.awt    如果键盘布局在对话激活时被更改,键盘布局就不会保持状态
6    JDK-8354646    client-libs/java.awt    java.awt.TextField 允许在双击文字开头和结尾时识别密码中的空格
7    JDK-8281523    client-libs/javax.accessibility    可及性:从字符串字面转换失去 const 限定符
8    JDK-8140527    client-libs/javax.swing    JinternalFrame的标题按钮宽度不正确
9    JDK-8236907    client-libs/javax.swing    将JTable添加到嵌套面板上不会绘制最后一行可见的行
10    JDK-8139228    client-libs/javax.swing    JFileChooser 将文件名渲染为 HTML 文档
11    JDK-8358532    client-libs/javax.swing    GTK L&F 中的 JFileChooser 仍然显示 HTML 文件名
12    JDK-8210807    client-libs/javax.swing    用 JScrollPane 打印 JTable 打印的表格时,没有填充行
13    JDK-8257810    client-libs/javax.swing    只有第一页会用 JTable.scrollRectToVisible 打印
14    JDK-8322135    client-libs/javax.swing    在 Windows L&F 中打印 JTable 会触发 InternalError:HTHEME 为空
15    JDK-8349188    client-libs/javax.swing    LineBorder 的缩放不正确
16    JDK-8358813    client-libs/javax.swing    JPasswordField 通过删除快捷方式识别密码中的空格
17    JDK-8370465    client-libs/javax.swing    MenuItem 组件从右向左向的问题
18    JDK-8307990    core-libs/java.lang    jspawnhelper 必须关闭其写入一侧的管道,才能读取
19    JDK-8311645    core-libs/java.lang    jspawnhelper spawnChild 在 JDK-8307990 之后发生内存泄漏
20    JDK-8280124    core-libs/java.lang    减少从 UTF-8 编码字节中解码拉丁 1 字符的分支
21    JDK-8282047    core-libs/java.lang    增强StringDecode/Encode微基准测试
22    JDK-8365086    core-libs/java.net    CookieStore.getURIs() 和 get(URI) 应该返回一个不可变的列表
23    JDK-8369184    core-libs/java.util:i18n    对于不同哈希码值的不相等实例,SimpleTimeZone 等于 () 返回为真
24    JDK-8328085    热点/编译器    C2:免费后在PhaseChaitin使用::Register_Allocate()
25    JDK-8364993    热点/JFR    JFR:关闭JDK。default.jfc 中的 ModuleExport
26    JDK-8364556    热点/JFR    JFR:在default.jfc中禁用SymbolTableStatistics和StringTableStatistics
27    JDK-8369992    热点/JFR    JFR:在default.jfc中禁用占位符、加载约束和保护域缓存表统计
28    JDK-8328997    热点/运行时    移除 GrowableArray 中不必要的模板参数列表
29    JDK-8317132    热点/运行时    准备允许的热点——
30    JDK-8361447    热点/运行时    [重做]已检查的 JNI 版本 Release<type>ArrayElements 需要过滤掉已知的包裹数组
31    JDK-8364235    热点/运行时    JDK-8361447 修复后,GuardedMemory 的对齐要求失效
32    JDK-8364660    热点/运行时    ClassVerifier::ends_in_athrow() 应该被移除
33    JDK-8306579    基础设施/其他    考虑用 /Zc:throwingNew 来构建
34    JDK-8317332    security-libs/java.security    准备允许的安保——
35    JDK-8325680    security-libs/org.ietf.jgss    deleteGSSCB 中的未初始化内存 GSSLibStub.c:179
36    JDK-8365790    tools/jpackage    应用程序映像的关闭钩子在 Windows 上无法使用

大家还下载了