java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java 17 新特性

Java 17的一些新特性介绍

作者: sofia 

这篇文章主要介绍了Java 17的一些新特性介绍,Java添加了许多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上看到更多关于此功能的示例和详细说明。

到此这篇关于Java 17的一些新特性介绍的文章就介绍到这了,更多相关Java 17 新特性内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文