当前位置:主页 > 软件编程 > JAVA代码 >

Java 17的一些新特性介绍

时间:2022-06-28 09:17:22 | 栏目:JAVA代码 | 点击:

前言

Java17将是一个长期支持的LTS版本。

Java采用了6个月的发布周期。也就是说,它将每6个月发布一个新版本的Java。每隔3年,LTS版本就会发布一次。目前,Java 11是LTS版本,于2018年9月发布。但在Java17发布后,它将是最新的LTS支持。

许多组织依赖LTS版本,所以他们使用的是Java11。但在Java17发布后,他们将使用Java17(可能)。

自从将Java9发布到Java16之后,Java添加了许多Java开发人员渴望的特性和改进。看看它,我们可以说Java正在缓慢而稳定地追赶其他编程语言。它让Java开发人员感到高兴,因为我们已经听腻了“Java已死”。

Java 17中的Sealed 密封类

sealed class 密封类允许描述哪个类或接口可以扩展或实现这个类或接口。简而言之,我们可以限制谁可以使用这个类或接口。假设我们有一个学生抽象类,如果我们将其设为一个密封类,并且只允许ScienceStudentCommerceSudent扩展该类,那么只有这些类才能扩展该Student,而其他类如果试图扩展该类,则会出错。

public abstract sealed class Student permits ScienceStudent , CommerceStudent { ... }

这提供了一种比访问修饰符更具声明性的方法来限制超类的使用。

Java 17提供了更好的随机生成器

Java 17为伪随机数生成器(PRNG)提供了新的接口类型和实现。它引入了一个名为RandomGenerator的新接口。该接口的目标是为所有现有和新的PRNG提供统一的API。

RandomGenerator提供名为ints、longs、doubles、nextBoolean、nextInt、nextLong、nextDouble和nextFloat的方法,以及它们当前的所有参数变化。以下是提供的四个新的专用随机发生器接口:

所有这些接口都扩展了接口。

此功能的目标是:

Java对增强安全性的关注

通过JEP403,Java对JDK内部进行了强封装。这意味着,它将限制用户直接使用Java的内部内容,并鼓励用户使用标准API。使用内部构件的原因可能会导致问题,尤其是在安全方面。此功能的目标是:

另一个安全更新是JEP 411:不推荐删除安全管理器。嗯,这不完全是一个更新,而是朝着删除一个功能迈出的一步。安全管理器可以追溯到Java 1.0。多年来,它一直不是保护客户端Java代码的主要手段,也很少用于保护服务器端代码。因此,在即将发布的Java版本中,它将完全从Java中删除。

Pattern Matching For Switch预览

此功能是一个预览功能,不会在标准软件包中提供。

在Java16中,我们获得了“instanceOf的模式匹配”功能。类似地,这种切换模式匹配功能将改进普通旧的单equals类型的切换表达式。下面是一个开关表达式的代码简介。

Object o = 123L;
String formatted = switch (o) {
    case Integer i -> String.format("int %d", i);
    case Long l    -> String.format("long %d", l);
    case Double d  -> String.format("double %f", d);
    case String s  -> String.format("String %s", s);
    default        -> o.toString();
};

你可以在JEP 406上看到更多关于此功能的示例和详细说明。

您可能感兴趣的文章:

相关文章