JDK21更新特性详解(四)

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: JDK21更新特性详解(四)

| 448: | Vector API (Sixth Incubator) |

1. 什么是 Vector API (Sixth Incubator)?

Vector API (Sixth Incubator) 是 Java 平台的一个项目,旨在提供一种简单且高效的方式来执行向量化计算。它引入了新的类和接口,以支持使用 SIMD(Single Instruction, Multiple Data)指令集进行并行计算。

2. 为什么需要 Vector API (Sixth Incubator)?

在许多应用程序中,存在大量的数据并行计算任务,例如图像处理、科学计算和机器学习等领域。传统的 Java 编程模型无法充分利用现代硬件的并行计算能力,导致性能低下。而 Vector API (Sixth Incubator) 的目标就是通过向量化计算来提高这些应用程序的性能。

3. Vector API (Sixth Incubator) 的实现原理?

Vector API (Sixth Incubator) 基于 SIMD 指令集,即单指令多数据流指令集。SIMD 指令集可以同时对多个数据元素执行相同的操作,从而实现并行计算。Vector API (Sixth Incubator) 提供了一组新的类和接口,使开发人员能够直接编写基于 SIMD 指令集的代码。

具体来说,Vector API (Sixth Incubator) 引入了 java.util.vector 包,其中包含了一些新的类和接口,如 VectorFloatVectorIntVector 等。这些类提供了一组向量化操作方法,例如加法、减法、乘法等,以及对应的掩码操作。

在底层实现上,Vector API (Sixth Incubator) 使用了特定硬件平台的 SIMD 指令集来执行向量化计算。具体实现细节会依赖于不同的硬件架构和操作系统。

4. Vector API (Sixth Incubator) 的优点

  • 提高性能:通过利用 SIMD 指令集进行并行计算,可以显著提高应用程序的性能。
  • 简化编程模型:Vector API (Sixth Incubator) 提供了一组简单易用的类和接口,使开发人员能够直接编写基于 SIMD 指令集的代码,而无需手动优化。

5. Vector API (Sixth Incubator) 的缺点

  • 平台限制:Vector API (Sixth Incubator) 的实现依赖于特定的硬件平台和操作系统,因此在不同的平台上可能存在兼容性问题。
  • 学习成本:使用 Vector API (Sixth Incubator) 需要学习新的类和接口,并理解 SIMD 指令集的工作原理,对于一些开发人员来说可能需要花费一定的时间和精力。

6. Vector API (Sixth Incubator) 的使用示例

下面是一个简单的使用 Vector API (Sixth Incubator) 进行向量化计算的示例:

import java.util.vector.*;
public class VectorExample {
    public static void main(String[] args) {
        int size = 8;
        // 创建两个向量对象
        FloatVector a = FloatVector.broadcast(size, 2.0f);
        FloatVector b = FloatVector.broadcast(size, 3.0f);
        // 执行向量化加法操作
        FloatVector result = a.add(b);
        // 输出结果
        float[] array = new float[size];
        result.intoArray(array, 0);
        for (float value : array) {
            System.out.println(value);
        }
    }
}

在上述示例中,我们创建了两个长度为 8 的浮点数向量,并执行了向量化的加法操作。最后将结果输出到数组中并打印出来。

7. Vector API (Sixth Incubator) 的使用注意事项

  • 硬件兼容性:由于 Vector API (Sixth Incubator) 的实现依赖于特定的硬件平台和操作系统,因此在使用之前需要确保目标平台支持 SIMD 指令集。
  • 性能优化:虽然 Vector API (Sixth Incubator) 可以提高应用程序的性能,但要获得最佳性能还需要进行适当的优化。例如,避免频繁的向量化操作和数据拷贝等。

8. 总结

Vector API (Sixth Incubator) 是 Java 平台的一个项目,旨在提供一种简单且高效的方式来执行向量化计算。它基于 SIMD 指令集,并通过引入新的类和接口来支持并行计算。使用 Vector API (Sixth Incubator) 可以提高应用程序的性能,但需要注意硬件兼容性和适当的性能优化。

| 449: | Deprecate the Windows 32-bit x86 Port for Removal |

名字太长了。。后面简称 449

1. 什么是 JEP 449?

JEP 449(Java Enhancement Proposal 449)是一个针对 OpenJDK 的提案,旨在废弃并最终移除 Windows 32 位 x86 平台上的 Java 支持。

2. 为什么需要废弃 Windows 32 位 x86 平台上的 Java 支持?

主要有以下几个原因:

  • 「过时的硬件和操作系统」:Windows 32 位 x86 平台已经逐渐被淘汰,现代计算机普遍采用 64 位架构。同时,大多数新版本的 Windows 操作系统也只提供了 64 位版本。
  • 「性能限制」:32 位架构限制了可寻址内存空间的大小,导致无法充分利用现代计算机的资源。而 64 位架构可以提供更大的内存地址空间,从而提高应用程序的性能和扩展性。
  • 「安全问题」:32 位架构存在一些安全漏洞和限制,例如缓冲区溢出等。而 64 位架构通过引入更多的保护机制来增加应用程序的安全性。

基于以上原因,废弃 Windows 32 位 x86 平台上的 Java 支持是合理且必要的。

3. JEP 449 的实现原理

JEP 449 的实现原理涉及到编译器、虚拟机和库等多个方面的改动。

  • 「编译器层面」:废弃 32 位 x86 平台上的 Java 支持需要对编译器进行修改,禁止生成 32 位 x86 架构的目标代码。
  • 「虚拟机层面」:虚拟机需要对内存管理、垃圾回收等进行调整,以适应 64 位架构的特性。同时,还需要更新与操作系统交互的部分代码,确保在 64 位环境下正常运行。
  • 「库层面」:一些与硬件相关的库可能需要重新编写或者替换为 64 位版本,以充分利用 64 位架构的优势。

具体实现细节可以参考 JEP 449 提案中的详细说明。

4. JEP 449 的优点

  • 「性能提升」:64 位架构可以提供更大的内存地址空间,从而提高应用程序的性能和扩展性。
  • 「安全增强」:64 位架构引入了更多的保护机制,提高了应用程序的安全性。
  • 「与现代计算机趋势相符」:Windows 32 位 x86 平台已经逐渐被淘汰,废弃该平台上的 Java 支持是与时俱进的举措。

5. JEP 449 的缺点

  • 「向后兼容性问题」:废弃 Windows 32 位 x86 平台上的 Java 支持可能导致一些现有的应用程序无法在该平台上运行。这需要开发人员进行相应的迁移和调整。
  • **对于仍然使用 32 位硬件和操作系统的用户而言,将无法继续获得新版本的 Java 更新和功能改进。

6. JEP 449 的使用示例

JEP 449 是一个 OpenJDK 的提案,它主要影响到 OpenJDK 的开发者和 Windows 32 位 x86 平台上的 Java 用户。对于开发者来说,他们需要根据 JEP 449 的实施情况,适时地迁移和调整自己的应用程序代码。对于 Windows 32 位 x86 平台上的 Java 用户来说,他们需要考虑升级到 64 位架构的计算机和操作系统,以继续获得最新的 Java 更新和功能改进。

7. JEP 449 的使用注意事项

  • 开发者需要及时关注 JEP 449 的实施情况,并根据需要进行相应的迁移和调整。
  • Windows 32 位 x86 平台上的 Java 用户需要考虑升级到 64 位架构的计算机和操作系统,以继续获得最新的 Java 更新和功能改进。

8. 总结

JEP 449 旨在废弃并最终移除 Windows 32 位 x86 平台上的 Java 支持。这是基于该平台已经逐渐被淘汰、性能限制和安全问题等原因做出的合理举措。废弃该平台上的 Java 支持可以提高应用程序的性能和安全性,并与现代计算机趋势相符。开发者需要及时关注 JEP 449 的实施情况,并根据需要进行相应的迁移和调整。Windows 32 位 x86 平台上的 Java 用户需要考虑升级到 64 位架构的计算机和操作系统,以继续获得最新的 Java 更新和功能改进。

| 451: | Prepare to Disallow the Dynamic Loading of Agents |

1. 什么是动态加载代理禁用准备(Prepare to Disallow the Dynamic Loading of Agents)?

动态加载代理禁用准备(Prepare to Disallow the Dynamic Loading of Agents)是一个 Java 增强提案,其目标是在 JVM 中禁止动态加载代理。代理是一种能够修改或监视应用程序行为的机制,它可以通过字节码注入来实现。

2. 为什么需要动态加载代理禁用准备?

动态加载代理允许开发人员在运行时修改和监视 Java 应用程序的行为。虽然这对于调试和性能分析等方面非常有用,但也存在潜在的安全风险。恶意代码可能会利用动态加载代理的功能来执行恶意操作,例如窃取敏感信息、篡改数据等。

因此,为了加强 Java 应用程序的安全性,限制动态加载代理的使用是很有必要的。

3. 动态加载代理禁用准备的实现原理

动态加载代理禁用准备的实现涉及到以下几个方面:

3.1 修改 ClassLoader

该提案建议修改 Java 虚拟机的类加载器,以阻止动态加载代理。具体而言,将在java.lang.ClassLoader 类中添加一个新的方法boolean disallowDynamicAgentLoading(),默认返回false。当该方法被调用时,将返回true,表示禁止动态加载代理。

3.2 修改 Instrumentation API

为了支持 ClassLoader 的修改,还需要对 Java 虚拟机的 Instrumentation API 进行相应的更改。具体而言,将在java.lang.instrument.Instrumentation 接口中添加一个新的方法boolean isDynamicAgentLoadingAllowed(),默认返回true。当该方法返回false时,表示禁止动态加载代理。

3.3 更新安全管理器

此外,还建议更新 Java 虚拟机的安全管理器(SecurityManager),以允许检查是否允许动态加载代理。这样可以通过安全策略来控制哪些代码可以使用动态加载代理功能。

4. 动态加载代理禁用准备的优点

  • 提高 Java 应用程序的安全性:禁止动态加载代理可以防止恶意代码利用其功能执行潜在的危险操作。
  • 简化安全配置:通过更新安全管理器和类加载器,可以更方便地控制动态加载代理的使用权限,简化安全配置过程。

5. 动态加载代理禁用准备的缺点

  • 可能影响现有代码:如果现有代码依赖于动态加载代理的功能,那么禁用它可能会导致这些代码无法正常工作。因此,在应用该增强提案之前,需要仔细评估现有代码的依赖关系。

6. 动态加载代理禁用准备的使用示例

以下是一个简单的示例,展示了如何使用动态加载代理禁用准备:

import java.lang.instrument.Instrumentation;
public class AgentLoader {
    public static void premain(String agentArgs, Instrumentation inst) {
        // 禁止动态加载代理
        if (inst.isDynamicAgentLoadingAllowed()) {
            throw new SecurityException("Dynamic loading of agents is not allowed");
        }
        // 其他初始化操作...
    }
}

在上述示例中,premain方法是 Java 代理的入口点。通过调用isDynamicAgentLoadingAllowed()方法,可以检查是否允许动态加载代理。如果不允许,则抛出安全异常。

7. 动态加载代理禁用准备的使用注意事项

  • 在使用动态加载代理禁用准备之前,需要仔细评估现有代码是否依赖于动态加载代理的功能。
  • 需要更新相关的类加载器和安全管理器来支持禁止动态加载代理的功能。
  • 使用动态加载代理禁用准备时,需要确保应用程序的安全策略能够正确地控制动态加载代理的使用权限。

8. 总结

动态加载代理禁用准备是一个 Java 增强提案,旨在禁止动态加载代理以提高应用程序的安全性。它通过修改类加载器、Instrumentation API 和安全管理器来实现禁止动态加载代理的功能。尽管这样做可以增加应用程序的安全性,但也可能影响依赖于动态加载代理的现有代码。因此,在使用该功能之前需要仔细评估现有代码的依赖关系。

| 452: | Key Encapsulation Mechanism API |

1. 什么是 Key Encapsulation Mechanism API?

Key Encapsulation Mechanism (KEM) API 是一个 Java API,用于支持密钥封装机制。密钥封装是一种加密技术,它将一个对称密钥(也称为会话密钥)与公钥结合使用,以便在不直接暴露私钥的情况下安全地传输密钥。

KEM API 提供了一组方法和类,用于生成、封装和解封装密钥。它可以与现有的密码学算法和协议集成,提供更高级别的密钥管理功能。

2. 为什么需要 Key Encapsulation Mechanism API?

在传统的密钥交换过程中,通常需要事先共享或分发密钥。这可能存在许多安全风险,例如密钥泄露、中间人攻击等。而密钥封装机制通过使用公钥进行密钥交换,避免了这些问题。

Key Encapsulation Mechanism API 的出现使得开发者能够更方便地实现密钥封装机制,并提供了更高级别的密钥管理功能。它简化了密钥生成、封装和解封装的过程,同时保证了安全性和可靠性。

3. Key Encapsulation Mechanism API 的实现原理

Key Encapsulation Mechanism API 的实现原理基于非对称加密算法和密钥封装机制。它使用公钥进行密钥交换,并通过将会话密钥封装在一个安全的密文中,以确保密钥的安全传输。

具体实现过程如下:

  1. 生成一对公私钥对。
  2. 使用公钥进行密钥封装,生成一个密文。
  3. 将密文发送给接收方。
  4. 接收方使用私钥解封装密文,得到会话密钥。
  5. 双方可以使用会话密钥进行加密通信。

4. Key Encapsulation Mechanism API 的优点

  • 「安全性高」:Key Encapsulation Mechanism API 使用了非对称加密算法和密钥封装机制,能够提供较高的安全性,避免了密钥泄露和中间人攻击等问题。
  • 「易于使用」:API 提供了简单易用的方法和类,开发者可以轻松地生成、封装和解封装密钥,无需深入了解底层算法和协议。
  • 「灵活性强」:API 可以与现有的密码学算法和协议集成,提供更高级别的密钥管理功能,满足不同场景的需求。

5. Key Encapsulation Mechanism API 的缺点

  • 「依赖于非对称加密算法」:Key Encapsulation Mechanism API 的实现依赖于非对称加密算法,这些算法可能存在性能上的瓶颈和限制。
  • 「需要保护私钥的安全」:由于使用了非对称加密算法,私钥的安全至关重要。开发者需要采取措施来保护私钥的机密性和完整性。

6. Key Encapsulation Mechanism API 的使用示例

下面是一个简单的使用示例,演示了如何使用 Key Encapsulation Mechanism API 进行密钥封装和解封装:

import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.KeyAgreement;
import javax.crypto.Cipher;
public class KEMExample {
    public static void main(String[] args) throws Exception {
        // 生成公私钥对
        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
        KeyPair keyPair = keyPairGenerator.generateKeyPair();
        // 创建 KeyAgreement 对象
        KeyAgreement keyAgreement = KeyAgreement.getInstance("DH");
        keyAgreement.init(keyPair.getPrivate());
        // 执行密钥协商过程
        keyAgreement.doPhase(keyPair.getPublic(), true);
        // 生成会话密钥
        byte[] sharedSecret = keyAgreement.generateSecret();
        // 封装会话密钥
        Cipher cipher = Cipher.getInstance("AES");
        cipher.init(Cipher.WRAP_MODE, keyPair.getPublic());
        byte[] wrappedKey = cipher.wrap(sharedSecret);
        // 解封装会话密钥
        cipher.init(Cipher.UNWRAP_MODE, keyPair.getPrivate());
        byte[] unwrappedKey = cipher.unwrap(wrappedKey, "AES", Cipher.SECRET_KEY);
        // 输出结果
        System.out.println("Shared Secret: " + new String(sharedSecret));
        System.out.println("Unwrapped Key: " + new String(unwrappedKey));
    }
}

7. Key Encapsulation Mechanism API 的使用注意事项

  • 开发者需要选择合适的非对称加密算法和密钥封装机制,根据具体需求进行配置。
  • 私钥的安全至关重要,开发者应该采取措施来保护私钥的机密性和完整性。
  • 密钥封装过程中生成的密文需要通过安全信道传输,以确保密钥的安全性。

8. 总结

Key Encapsulation Mechanism API 是一个用于支持密钥封装机制的 Java API。它提供了一组方法和类,用于生成、封装和解封装密钥。通过使用公钥进行密钥交换,避免了传统密钥交换方式中存在的安全风险。API 的实现原理基于非对称加密算法和密钥封装机制,能够提供较高的安全性和灵活性。开发者可以轻松地使用 API 进行密钥封装和解封装操作,并与现有的密码学算法和协议集成,满足不同场景的需求。然而,API 的使用需要注意私钥的安全性和密文的传输安全。

| 453: | Structured Concurrency (Preview) |

什么是结构化并发(Structured Concurrency)?

结构化并发是一种用于简化并发编程的 API。它将在不同线程中运行的相关任务组视为一个单独的工作单元,从而简化错误处理和取消操作,提高可靠性,并增强可观察性。

为什么需要结构化并发?

传统的并发编程模型,如ExecutorService API,由于其无限制的并发模式,引入了复杂性和风险。这些模型没有强制执行或跟踪任务和子任务之间的关系,使得管理和观察并发任务变得困难。结构化并发模型认为任务结构应该反映代码结构,在单线程代码中,执行总是强制实施任务和子任务的层次结构,每个子任务的生命周期相对于其他子任务受到代码的语法块结构的控制。

结构化并发旨在消除与并发编程相关的常见风险,例如线程泄漏和取消延迟,并增强并发代码的可观察性。

结构化并发的实现原理

结构化并发通过引入新的 API 来实现,其中最重要的类是StructuredTaskScopeStructuredTaskScope 封装了一组相关的任务,这些任务应该一起完成,如果任何子任务失败,则会取消剩余的子任务。

在结构化并发中,使用StructuredTaskScope 创建一个作用域,在该作用域内可以派生出多个子任务。这些子任务将被视为整体,并且它们之间存在依赖关系。当所有子任务完成后,可以对它们进行处理,例如获取结果或抛出异常。

结构化并发的优点

  • 简化并发编程:结构化并发提供了一种更简单、更直观的方式来处理并发任务。
  • 错误处理和取消操作:通过将相关任务组合成一个单元,结构化并发使错误处理和取消操作更加容易和可靠。
  • 提高可靠性:结构化并发模型消除了常见的风险,如线程泄漏和取消延迟,从而提高了并发代码的可靠性。
  • 增强可观察性:结构化并发模型使得观察并发任务的执行状态变得更加方便。

结构化并发的缺点

  • 预览功能:目前,结构化并发仍处于预览阶段,需要启用预览功能才能使用。

结构化并发的使用示例

下面是一个使用结构化并发的示例代码:

Response handle() throws ExecutionException, InterruptedException {
    try (var scope = new StructuredTaskScope.ShutdownOnFailure()) {
        Supplier<String>  user  = scope.fork(() -> findUser());
        Supplier<Integer> order = scope.fork(() -> fetchOrder());
        scope.join()
             .throwIfFailed();
        return new Response(user.get(), order.get());
    }
}

在这个示例中,我们创建了一个新的StructuredTaskScope作用域,并使用它派生了两个子任务:一个执行findUser() 方法,另一个执行fetchOrder()方法。一旦两个子任务都完成,就可以使用它们的结果创建一个新的Response对象。

结构化并发的使用注意事项

  • 结构化并发是一个预览功能,默认情况下被禁用。要使用 StructuredTaskScope API,开发人员必须启用预览功能来编译代码。
  • 使用结构化并发时,通常不直接使用 StructuredTaskScope 类,而是使用实现关闭策略的两个子类之一。这些子类分别是 ShutdownOnFailureShutdownOnSuccess,支持当第一个子任务失败或成功时关闭作用域的模式。
  • 运行结构化并发程序时,需要使用 --enable-preview选项启用预览功能。

总结

结构化并发是一种用于简化并发编程的 API,它将相关任务组合成一个单元,从而简化错误处理和取消操作,提高可靠性,并增强可观察性。通过引入StructuredTaskScope 类和相关的子类,结构化并发提供了一种更简单、更直观的方式来处理并发任务。然而,需要注意的是,结构化并发目前仍处于预览阶段,并且需要启用预览功能才能使用。

JDK 21 将是大多数供应商的长期支持 (LTS) 版本。有关自上一个 LTS 版本 JDK 17 以来集成的 JEP 的完整列表,请参阅 here.

Schedule

| 2023/06/08 | | 第一阶段缓慢降级(从主分支派生)|

| 2023/07/20 | | 第二阶段缓慢降级|

| 2023/08/10 | | 初始候选发行版|

| 2023/08/24 | | 最终候选发行版|

| 2023/09/19 | | 正式发布 |

最后更新时间:2023 年 9 月 19 日 10:53 UTC

本文由 mdnice 多平台发布


相关文章
|
1月前
|
容器
jdk8新特性-详情查看文档
jdk8新特性-详情查看文档
49 7
|
4月前
|
容器
jdk8新特性-详情查看文档
jdk8新特性-详情查看文档
51 3
|
3月前
|
存储 安全 Java
JDK1.8 新的特性
JDK1.8 新的特性
33 0
|
4月前
|
编解码 安全 Java
jdk8新特性-接口和日期处理
jdk8新特性-接口和日期处理
|
5月前
|
Java API
JDK8到JDK25版本升级的新特性问题之使用Collectors.teeing()来计算一个列表中学生的平均分和总分如何操作
JDK8到JDK25版本升级的新特性问题之使用Collectors.teeing()来计算一个列表中学生的平均分和总分如何操作
|
5月前
|
Java API Apache
JDK8到JDK24版本升级的新特性问题之在Java中,HttpURLConnection有什么局限性,如何解决
JDK8到JDK24版本升级的新特性问题之在Java中,HttpURLConnection有什么局限性,如何解决
|
5月前
|
Oracle Java 关系型数据库
JDK8到JDK29版本升级的新特性问题之未来JDK的升级是否会成为必然趋势,如何理解
JDK8到JDK29版本升级的新特性问题之未来JDK的升级是否会成为必然趋势,如何理解
|
5月前
|
Oracle 安全 Java
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
|
5月前
|
Java API 开发者
JDK8到JDK17版本升级的新特性问题之SpringBoot选择JDK17作为最小支持的Java lts版本意味着什么
JDK8到JDK17版本升级的新特性问题之SpringBoot选择JDK17作为最小支持的Java lts版本意味着什么
165 0
JDK8到JDK17版本升级的新特性问题之SpringBoot选择JDK17作为最小支持的Java lts版本意味着什么
|
4月前
|
Java 编译器 API
JDK8新特性--lambda表达式
JDK8的Lambda表达式是Java语言的一大进步。它为Java程序提供了更多的编程方式,让代码更加简洁,也让函数式编程的概念在Java中得到了体现。Lambda表达式与Java 8的其他新特性,如Stream API、新的日期时间API一起,极大地提高了Java编程的效率和乐趣。随着时间的流逝,Java开发者对这些特性的理解和应用将会越来越深入,进一步推动Java语言和应用程序的发展。
18 0