在 Project Loom 的保护下,JEP 425引入了虚拟线程,旨在显着减少在 Java 平台上编写、维护和观察高吞吐量并发应用程序的工作量。考虑以下示例:
- public class Main {
-
- public static void main(String[] args) throws InterruptedException {
- var vThread = Thread.startVirtualThread(() -> {
- System.out.println("Hello from the virtual thread");
- });
-
- vThread.join();
- }
- }
由于这是一个预览功能,因此开发人员需要提供--enable-preview标志来编译此代码,如以下命令所示:
javac --release 19 --enable-preview Main.java
运行程序也需要相同的标志:
java --enable-preview Main
也可以使用源码启动器直接运行它。在这种情况下,命令行将是:
java --source 19 --enable-preview Main.java
JShell选项也可用,但也需要启用预览功能:
jshell --enable-preview
虽然Thread.startVirtualThread(Runnable)是创建虚拟线程的便捷方式,但添加了新的 API,如Thread.Builder、Thread.ofVirtual()和Thread.ofPlatform(),用于创建虚拟线程和平台线程。
结构化并发允许您将在不同线程上运行的多个任务视为原子操作,从而使多线程编程更容易。结果,错误处理和取消将被简化,可靠性将增加,可观察性将得到提升。让我们看一个例子:
- Response handle() throws ExecutionException, InterruptedException {
-
- try (var scope = new StructuredTaskScope.ShutdownOnFailure()) {
- Future<String> user = scope.fork(() -> findUser());
- Future<Integer> order = scope.fork(() -> fetchOrder());
-
- scope.join(); // Join both forks
- scope.throwIfFailed(); // ... and propagate errors
-
- // Here, both forks have succeeded, so compose their results
- return new Response(user.resultNow(), order.resultNow());
- }
- }
javac --release 19 --enable-preview --add-modules jdk.incubator.concurrent Main.java
运行程序也需要相同的标志:
java --enable-preview --add-modules jdk.incubator.concurrent Main;
也可以使用源代码启动器直接运行它。在这种情况下,命令行将是:
java --source 19 --enable-preview --add-modules jdk.incubator.concurrent Main.java
JShell 选项也可用,但也需要启用预览功能:
jshell --enable-preview --add-modules jdk.incubator.concurrent
第三个预览是为 Java 编程语言添加 switch 表达式和语句的模式。为了简洁和安全地表达复杂的面向数据的查询,它允许针对多种模式进行测试,每种模式都有不同的操作。考虑以下示例:
这也是一个预览功能,需要开发者添加--enable-preview.
通过利用Foreign Function and Memory API,Java 应用程序可以与未内置在 JRE 中的数据进行通信和使用。没有 JNI 的麻烦和安全问题,Java 程序现在可以访问本机内存、调用本机函数和处理本机数据。例子:
- package ca.bazlur;
-
- public class PatternMatching {
-
- public static String transform(Integer status) {
-
- return switch (status) {
- case 200 -> "Ok";
- case 301 -> "Moved Permanently";
- case 404 -> "Not found";
- case 500 -> "Internal Server Error";
- case Number n when n.intValue() >= 600 -> "Invalid";
- default -> "Valid";
- };
- }
-
- public static void main(String[] args) {
- System.out.println(transform(200));
- System.out.println(transform(600));
- System.out.println(transform(404));
- }
- }
记录模式的目的是用可用于解构记录值的记录模式来丰富语言。为了“...启用一种健壮的、声明性的和可组合的数据导航和处理形式”,记录模式可以与类型模式结合使用。