oracle 发布了另一个版本的 java,在字节码操作、工具开发、代码质量等方面进行了强大的增强。以下是最有趣和最有用的 java 23 功能 - 来自在该技术领域拥有 10 多年经验的 java 团队负责人的视角。
随着 java 的不断发展,每个新版本都旨在引入可提高语言性能、可用性和灵活性的功能。通过采用此版本,您可以保持领先地位,并为这些功能在未来的 lts 版本中变得稳定做好准备。
在本文中,我将向您快速概述 java 23 中的重大变化,重点关注最值得注意的 jep(jdk 增强提案)。对之前的变化感兴趣的人可以查看我之前关于 java 21 功能的文章,您还可以阅读 dariusz wawer 的旧文章,其中详细描述了 java 17 功能(以及与 java 8 的比较)。
对于代码示例,您必须将 --enable-preview 标志添加到编译器参数中。
基本类型一直是 java 不可或缺的一部分,但是以模式、instanceof 和 switch 构造来处理它们是有限的。 jep 455 旨在扩展模式匹配和 switch 语句以支持原始类型。
static string processinput(object obj) { return switch (obj) { case integer i -> "integer value: %s".formatted(i); case double d -> "double value: %s".formatted(d); default -> "unknown type"; }; } public static void main(string[] args) { system.out.println(processinput(10)); // integer value: 10 system.out.println(processinput(5.5)); // double value: 5.5 }
此增强功能使开发人员能够编写更清晰、更简洁的代码。
java 的类文件格式对于字节码操作和工具开发至关重要。 jep 466 引入了新的类文件 api 的第二个预览版,简化了对 java 类文件的访问和操作,而无需开发人员依赖 asm 或 bcel 等第三方库。
这个 api 将使那些使用需要检查或修改类文件的框架、编译器或工具的人受益匪浅。凭借其简单的设计,它增强了灵活性,同时让开发人员更接近 java 的本机机制。您可以在下面找到与新 api 交互的简单示例:
public static void main(string[] args) throws ioexception { classfile classfile = classfile.of(); classmodel model=classfile.parse(paths.get("/home/exampleclass.class")); system.out.println("class name: " + model.thisclass()); // class name: 7 java23/exampleclass model.methods().foreach( method -> system.out.println(" - " + method.methodname())); //- <init> //- sayhello }
另一个预览功能为 java stream api 带来了非常好的增强。正如 jep473 文档所述,主要目标是使流管道更加灵活和更具表现力,并允许自定义中间操作来操纵无限大小的流。以下是内置收集操作的一些示例:
stream.of("a", "b", "c", "d", "e") .gather(gatherers.fold(() -> "", (a, b) -> a + b)) .foreach(system.out::println); //abcde stream.of("a", "b", "c", "d") .gather(gatherers.windowfixed(2)) .foreach(system.out::println); //[a, b] //[c, d]
当然,您可以创建收集器。为此,您只需实现 java.util.stream.gatherer 接口。
jep 481 引入了作用域值,这是线程局部变量的替代方案。它们提供了一种在特定范围内共享值的机制,使得使用多线程应用程序变得更容易。让我们深入研究代码示例:
public class jep481scopedvalues { private static scopedvalue<string> x = scopedvalue.newinstance(); public static void main(string[] args) { foo(); } static void foo() { scopedvalue.runwhere(x, "foo", () -> bar()); } static void bar() { system.out.println("printing x from bar(): " + x.get()); scopedvalue.runwhere(x, "bar", () -> baz()); system.out.println("printing x from bar(): " + x.get()); } static void baz() { system.out.println("printing x from baz(): " + x.get()); } } output: printing x from bar(): foo printing x from baz(): bar printing x from bar(): foo
jep 482 重新审视了 java 中构造函数的灵活性。传统上,java 中的构造函数体在如何构建以及如何处理异常方面受到限制。此 jep 引入了更多灵活性,允许开发人员在构造函数中编写更复杂的初始化逻辑,从而增强对对象创建的控制。
public class Java481FlexibleConstructors extends BigInteger { Java481FlexibleConstructors(long value) throws Exception { if (value < 0) throw new Exception("Invalid value"); //that wasn’t possible before System.out.println("Initialized with value: " + value); super(String.valueOf(value)); } }
除了我已经介绍过的 jep 之外,java 23 还引入了其他几个值得一提的增强功能:
如果您对更多 java 相关内容(包括深入研究版本 21 和 17)感兴趣,请查看我们博客上的一些其他出版物: