你好啊,我是大阳。
Java 13 于 2019 年 9 月 17 日发布。在这篇文章中,我们将介绍添加的一些特性以及一些代码示例。
Java13的主要更新内容如下:
使用yield,我们现在可以有效地从 switch 表达式返回值,并能够更容易实现策略模式。
package cn.dayangshuo.collectors;
/**
* @author DAYANG
*/
public class SwitchTest {
public static void main(String[] args) {
var me = 4;
var operation = "平方";
var result = switch (operation) {
case "加倍" -> {
yield me * 2;
}
case "平方" -> {
yield me * me;
}
default -> me;
};
System.out.println(result);
}
}
第二个预览功能是多行String的文本块,例如嵌入的 JSON、XML、HTML 等。
早些时候,为了在我们的代码中嵌入 JSON,我们将其声明为字符串文字:
String JSON_STRING
= "{\r\n" + "\"name\" : \"Baeldung\",\r\n" + "\"website\" : \"https://www.dayangshuo.cn/\"\r\n" + "}";
现在让我们使用字符串文本块编写相同的 JSON :
String TEXT_BLOCK_JSON = """
{
"name" : "Baeldung",
"website" : "https://www.dayangshuo.cn/"
}
""";
很明显,不需要转义双引号或添加回车。通过使用文本块,嵌入的 JSON 更易于编写,更易于阅读和维护。
一段时间以来,类数据共享 (CDS) 一直是 Java HotSpot VM 的一个突出特性。它允许在不同的 JVM 之间共享类元数据,以减少启动时间和内存占用。JDK 10 通过添加应用程序 CDS ( AppCDS ) 扩展了这种能力——让开发人员能够在共享存档中包含应用程序类。JDK 12 进一步增强了这个特性,默认包括 CDS 归档。
但是,归档应用程序类的过程很繁琐。要生成存档文件,开发人员必须先试运行他们的应用程序以创建类列表,然后将其转储到存档中。之后,该存档可用于在 JVM 之间共享元数据。
通过动态归档,JDK 13 简化了这个过程。现在我们可以在应用程序退出时生成一个共享存档。这消除了试运行的需要。
要使应用程序能够在默认系统存档之上创建动态共享存档,我们需要添加一个选项-XX:ArchiveClassesAtExit并将存档名称指定为参数:
java -XX:ArchiveClassesAtExit= -cp AppName
然后,我们可以使用新创建的存档通过-XX:SharedArchiveFile选项运行相同的应用程序:
java -XX:SharedArchiveFile= -cp AppName
Java 11 中引入了ZGC作为低延迟垃圾收集机制,因此 GC 暂停时间从未超过 10 毫秒。但是,与 G1 和 Shenandoah 等其他 HotSpot VM GC 不同,它没有配备将未使用的堆内存返回给操作系统的功能。
我们现在减少了内存占用并提高了性能。
从 Java 13 开始,ZGC 现在默认将未提交的内存返回给操作系统,直到达到指定的最小堆大小。如果我们不想使用此功能,我们可以通过以下方式回到 Java 11 方式:
此外,ZGC 现在支持的最大堆大小为 16TB。早些时候,限制到4TB 。
自 Java 出现以来,我们已经将 Socket(java.net.Socket和java.net.ServerSocket)API 视为 Java 不可或缺的一部分。然而,在过去的二十年里,它们从未现代化。它们是用遗留的 Java 和 C 编写的,既麻烦又难以维护。
Java 13 逆势而上,取代了底层实现,使 API 与未来的用户模式线程保持一致。提供者接口现在指向NioSocketImpl而不是PlainSocketImpl。这个新编码的实现基于与java.nio相同的内部基础结构。
同样,我们确实有办法回到使用PlainSocketImpl*。我们可以通过将系统属性-Djdk.net.usePlainSocketImpl设置为true来启动 JVM,以使用较旧的实现。默认值为*NioSocketImpl。
除了上面列出,Java 13 还为我们带来了一些更显着的变化: