Java 17 VS Java 8: 新旧对决,这些Java 17新特性你不容错过

news2024/11/24 19:31:44

在这里插入图片描述

🏅 欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!

Java是一门非常流行的编程语言,由于其跨平台性、可移植性以及强大的面向对象特性而备受青睐。Java最初由Sun Microsystems公司于1995年推出,随着时间的推移,Java发展迅速,版本不断更新。本篇博客将重点介绍Java 17与Java 8的对比,以及Java 17的新特性。

特征Java 17Java 8
引入2021年9月14日2014年3月
垃圾收集器ZGC(新型垃圾收集器)G1收集器
其他垃圾收集器Shenandoah GC,G1 GC,Parallel GC,Serial GCParallel GC,Serial GC
垃圾回收策略全堆回收和增量模式复制模式
应用程序类数据共享(AppCDS)支持不支持
JFR事件流使用异步处理提高性能未支持
条件性实例化卡片支持支持
嵌入式C / C ++库JDK不包括C / C ++编译器JDK不包括C / C ++编译器
算法升级SHA-3,SM3 / SM4,Ed448,RSASSA-PSS,X25519 / X448SHA-1,RC4,DES,MD5,DSA,DH
                                  Java 17 和 Java 8 的区别

一、Java 17与Java 8的对比

Java 17与Java 8是Java版本中的两个重要里程碑。Java 8是Java版本中的一次重大更新,于2014年发布,引入了很多新的特性和功能,包括Lambda表达式、Stream API、函数式接口等。Java 17是Java SE 17版本,于2021年9月发布,是Java SE 16的长期支持(LTS)版本。Java 17中也有一些新的特性和改进,我们将在后文中详细讨论。

二、性能比较

Java 17与Java 8在性能方面的比较非常重要。Java 8引入了一些性能改进,例如优化了字符串连接和数组排序等操作。Java 17在性能方面也有一些新的改进,例如:

  • 改进了JIT编译器,提高了应用程序的性能。
  • 改进了垃圾回收器,提高了垃圾回收的效率和吞吐量。
  • 引入了C++风格的内存管理,包括对堆内存分配的优化和对垃圾回收的改进。
    这些改进都可以提高Java应用程序的性能和响应速度。

三、语言特性比较

Java 8引入了一些新的语言特性,例如Lambda表达式和函数式接口。这些特性让Java程序员能够使用函数式编程的方式编写代码,从而使得代码更加简洁、易读、易维护。Java 17在语言特性方面也有一些新的改进,例如:

  • 引入了Sealed类,这是一种新的类修饰符,用于限制类的继承。这样可以使得代码更加安全、可维护。
  • 引入了Pattern Matching for Switch语法,这是一种新的switch语法,可以用于模式匹配。这样可以使得代码更加简洁、易读、易维护。
  • 引入了Record类,这是一种新的数据类,可以用于定义只有属性和访问器的简单数据对象。这样可以使得代码更加简洁、易读、易维护。
  • 这些改进都可以使得Java程序员能够使用更加先进、更加高效的语言特性编写代码。

四、应用场景比较

Java 8和Java 17都可以用于不同的应用场景,但是它们在一些方面有所不同。Java 8适用于开发中小型应用程序和Web应用程序,例如Web服务、企业级应用程序和桌面应用程序等。Java 8也可以用于开发大型应用程序,但是在大型应用程序中可能会出现一些性能问题。Java 17则更适合用于开发大型应用程序和高性能应用程序,例如高性能计算、云计算、大数据处理等。

五、Java 17的新特性

Java 17是Java SE 17版本,于2021年9月发布,是Java SE 16的长期支持(LTS)版本。Java 17中有许多新的特性和改进,以下是一些主要特性:

5.1 Sealed类

Sealed类是一种新的类修饰符,用于限制类的继承。Sealed类可以控制哪些类可以继承自它,这样可以使得代码更加安全、可维护。Sealed类的使用可以在编译时强制执行一些规则,从而避免运行时错误。

5.1.1 代码示例

public sealed abstract class Shape permits Circle, Rectangle {
    public abstract double calculateArea();
}

public final class Circle extends Shape {
    private double radius;

    public Circle(double radius) {
        this.radius = radius;
    }

    public double getRadius() {
        return radius;
    }

    public double calculateArea() {
        return Math.PI * radius * radius;
    }
}

public final class Rectangle extends Shape {
    private double length;
    private double width;

    public Rectangle(double length, double width) {
        this.length = length;
        this.width = width;
    }

    public double getLength() {
        return length;
    }

    public double getWidth() {
        return width;
    }

    public double calculateArea() {
        return length * width;
    }
}

代码说明:
在这个示例中,Shape 是一个抽象类,并且使用 permits 关键字,明确允许哪些类继承该类。Circle 和 Rectangle 是 Shape 的子类,并使用 final 关键字来表示它们是封闭类,不允许有其他子类继承它们。这种方式可以在编译时校验代码,并防止意外创建不受预期的子类。

5.2 Pattern Matching for Switch语法

Pattern Matching for Switch语法是一种新的switch语法,可以用于模式匹配。Pattern Matching for Switch语法可以根据不同的模式执行不同的操作,从而使得代码更加简洁、易读、易维护。Pattern Matching for Switch语法可以减少代码量,避免出现大量的if-else语句。

5.2.1 代码示例

public static void main(String[] args) {
    Object obj = "hello";

    switch (obj) {
        case String s && s.length() > 5 -> System.out.println("长字符串");
        case String s -> System.out.println("短字符串");
        case Integer i -> System.out.println("整型数");
        default -> System.out.println("不支持的类型");
    }
}

代码说明:
在这个示例中,我们首先定义了一个 Object 类型的变量 obj,它可能是一个字符串、整型数或其他类型的对象。

接下来,我们使用了 switch 语句,并对 obj 进行了几个模式匹配:

  • 如果 obj 是一个长度大于 5 的字符串,表达式 case String s && s.length() > 5 就会被匹配并执行相应的代码块。
  • 如果 obj 是一个短字符串,表达式 case String s 会匹配并执行相应代码块。
  • 如果 obj 是一个整型数,表达式 case Integer i 就会执行相应代码块。
  • 如果 obj 不属于以上任何一种类型,就会执行默认代码块。

5.3 Record类

Record类是一种新的数据类,可以用于定义只有属性和访问器的简单数据对象。Record类可以简化代码,使得代码更加易读、易维护。Record类的使用可以减少代码量,避免出现大量的getter和setter方法。

5.3.1 代码示例

public record Person(String name, int age) {}

public class RecordExample {
    public static void main(String[] args) {
        Person person = new Person("John", 30);

        System.out.println("Name: " + person.name());
        System.out.println("Age: " + person.age());
    }
}

代码说明:
在这个示例中,我们定义了一个名为 Person 的 Record 类,它有两个字段:name 和 age。Record 类会自动生成一个带有这些字段的构造函数、getter 方法和 equals、hashCode 和 toString 方法。

  • 我们在 main 方法中创建了一个 Person 对象,并使用 name() 和 age() 方法获取其名称和年龄信息,然后将其打印出来。

  • 使用 Record 类,我们可以更轻松地定义简单的数据类,而不需要手动编写大量的构造函数和 getter 方法。这可以使我们的代码更加简洁、清晰,并且更易于阅读和维护。

5.4 改进的垃圾回收器

Java 17中改进了垃圾回收器,提高了垃圾回收的效率和吞吐量。改进的垃圾回收器可以更加高效地回收内存,从而提高应用程序的性能和响应速度。

5.4.1 代码示例

public class GarbageCollectorExample {
    public static void main(String[] args) {
        List<Integer> list = new ArrayList<>();

        for (int i = 0; i < 1000000; i++) {
            list.add(i);
        }

        System.out.println("List size: " + list.size());

        System.gc(); // 调用垃圾回收器

        System.out.println("List size after GC: " + list.size());
    }
}

代码说明:
在这个示例中,我们使用了 ZGC 垃圾回收器来回收 list 对象占用的内存。我们在代码中使用了 System.gc() 方法来手动触发垃圾回收器。注意,在实际应用中,我们通常不需要手动触发垃圾回收器,因为 JVM 会自动进行垃圾回收操作。

ZGC 垃圾回收器具有可伸缩性和低延迟的特点,可以在处理大型、高并发应用程序时提供更好的性能和吞吐量。除了 ZGC,Java 17 中还引入了 Shenandoah 垃圾回收器,它也具有类似的高性能和低延迟的特点。

5.5 改进的JIT编译器

Java 17中改进了JIT编译器,提高了应用程序的性能。改进的JIT编译器可以更加高效地编译代码,从而提高应用程序的性能和响应速度。

5.5.1 代码示例

public class JITCompilerExample {
    public static void main(String[] args) {
        int sum = 0;
        for (int i = 0; i < 1000000; i++) {
            sum += i;
        }
        System.out.println("Sum is: " + sum);
    }
}

在Java 17中,可以通过添加以下命令行参数来启用Graal编译器:

-XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI -XX:+UseJVMCICompiler

代码说明:
当运行上述示例代码时,Graal编译器会自动将循环优化为一个简单的算术公式,从而大大提高了性能。

5.6 C++风格的内存管理

Java 17中引入了C++风格的内存管理,包括对堆内存分配的优化和对垃圾回收的改进。C++风格的内存管理可以使得Java应用程序更加高效,从而提高应用程序的性能和响应速度。

5.6.1 代码示例

import java.lang.management.MemoryPoolMXBean;
import java.lang.management.ManagementFactory;

public class MemoryManagementExample {

    public static void main(String[] args) throws InterruptedException {
        MemoryPoolMXBean heap = ManagementFactory.getMemoryPoolMXBeans().stream()
                .filter(p -> p.getName().equals("Java heap")).findFirst().orElseThrow();

            System.out.println("Heap memory utilization statistics:\n");

            try (var scope = heap.reserveMemory(1024 * 1024)) {
                long usedMemory = heap.getUsage().getUsed();
                long commitedMemory = heap.getUsage().getCommitted();

                System.out.printf("Before allocation: used=%d, committed=%d%n", usedMemory, commitedMemory);

                byte[] array = new byte[1024 * 1024];

                usedMemory = heap.getUsage().getUsed();
                int capacity = scope.getBytesReserved();

                System.out.printf("After allocation: used=%d, committed=%d, capacity=%d%n", usedMemory, commitedMemory,
                        capacity);
            }

            long usedMemory = heap.getUsage().getUsed();
            long commitedMemory = heap.getUsage().getCommitted();

            System.out.printf("After scope: used=%d, committed=%d%n", usedMemory, commitedMemory);
    }

}

代码说明:

  • 定义了一个名为 MemoryManagementExample 的类,然后获取 Java heap 内存池,并在 try-with-resources 语句中创建了一个名为 scope 的资源。

  • 然后,我们打印了内存使用率统计信息,并在 scope 内部分配了一个 1MB 的字节数组。我们使用 getBytesReserved() 方法获取作用域中已保留的字节数,并打印了内存使用情况和容量等信息。

  • 最后,我们打印了作用域结束后内存的使用情况。

5.7 增强的Java集合库

Java 17中增强了Java集合库,包括新增了一些集合类型和对现有集合类型的改进。增强的Java集合库可以提高开发人员的开发效率和代码质量,从而减少出现错误的可能性。同时,增强的Java集合库也可以提高应用程序的性能和响应速度,使得Java应用程序更加高效。

5.7.1 代码示例

  1. of() 方法:创建一个不可变的集合
List<String> list = List.of("apple", "banana", "orange");
Set<Integer> set = Set.of(1, 2, 3, 4);
Map<String, Integer> map = Map.of("apple", 1, "banana", 2, "orange", 3);
  1. forEach() 方法:遍历集合
List<String> list = List.of("apple", "banana", "orange");
list.forEach(name -> System.out.println(name));
Set<Integer> set = Set.of(1, 2, 3, 4);
set.forEach(number -> System.out.println(number));

  1. Collectors类:提供了一系列的归约操作
List<String> list = List.of("apple", "banana", "orange");
String joinedString = list.stream().collect(Collectors.joining("-", "[", "]"));
System.out.println(joinedString);

Map<String, Integer> map = Map.of("apple", 1, "banana", 2, "orange", 3);
Map<Integer, String> reversedMap = map.entrySet().stream().collect(Collectors.toMap(Map.Entry::getValue, Map.Entry::getKey));
System.out.println(reversedMap);

  1. takeWhile() 方法和 dropWhile() 方法:根据条件截取集合
List<Integer> list = List.of(1, 2, 3, 4, 5, 6, 7);
List<Integer> takenList = list.stream().takeWhile(number -> number < 5).collect(Collectors.toList());
System.out.println(takenList);

List<Integer> dropedList = list.stream().dropWhile(number -> number < 5).collect(Collectors.toList());
System.out.println(dropedList);

  1. toArray(IntFunction<T[]>) 方法:返回集合中的所有元素到一个新数组中
List<String> list = List.of("apple", "banana", "orange");
String[] array = list.toArray(String[]::new);
System.out.println(Arrays.toString(array));

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/564888.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[极客大挑战 2019]HardSQL1

拿到题目是一个登录界面 提交万能密码后拿到回显信息&#xff0c;说明页面存在过滤 burp抓包爆破后发现&#xff0c;所有736都是被过滤字符 联合注入和时间盲注被过滤&#xff0c;因为页面存在报错信息&#xff0c;所以尝试报错注入 因为空格也被过滤&#xff0c;所以我们使用括…

HOMER docker版本配置优化

概述 HOMER是一款100%开源的针对SIP/VOIP/RTC的抓包工具和监控工具。 HOMER是一款强大的、运营商级、可扩展的数据包和事件捕获系统&#xff0c;是基于HEP/EEP协议的VoIP/RTC监控应用程序&#xff0c;并可以使用即时搜索、处理和存储大量的信令、RTC事件、日志和统计信息。 …

机器学习-01概论

人们在生活中可能已经注意到了这样一种现象&#xff1a;我们能够轻松地通过相貌区分出日本人、韩国人和泰国人&#xff0c;但是面对英国人、俄罗斯人和德国人时&#xff0c;我们却很难辨认他们的面孔。造成这种现象的原因一方面是因为日韩泰都是我国的邻国&#xff0c;我们观察…

信号处理与分析-确定性信号的分析

目录 一、引言 二、确定性信号的定义 三、确定性信号的分类 四、确定性信号的分析方法 4.1 傅里叶变换 4.2 离散傅里叶变换 4.3 离散余弦变换 4.4 小波变换 五、确定性信号的处理方法 六、结论 一、引言 信号分析与处理是现代通信技术和信息处理技术的重要组成部分。…

Redis安装及其配置文件修改

一、redis 安装 点击即可下载 https://download.redis.io/releases/ 将下载后的包通过xftp上传到服务器 解压&#xff0c;我这边是解压到/usr/local目录下 -- 创建路径 mkdir /usr/local/redis -- 解压 tar -zxvf redis-4.0.0.tar.gz -C /usr/local/redis 为防止编译失败&am…

MyBatis-Plus精讲和使用注意事项

&#x1f353; 简介&#xff1a;java系列技术分享(&#x1f449;持续更新中…&#x1f525;) &#x1f353; 初衷:一起学习、一起进步、坚持不懈 &#x1f353; 如果文章内容有误与您的想法不一致,欢迎大家在评论区指正&#x1f64f; &#x1f353; 希望这篇文章对你有所帮助,欢…

【国产虚拟仪器】基于Zynq的雷达10Gbps高速PCIE数据采集卡方案(一)总体设计

2.1 引言 本课题是来源于雷达辐射源识别项目&#xff0c;需要对雷达辐射源中频信号进行采集传输 和存储。本章基于项目需求&#xff0c;介绍采集卡的总体设计方案。采集卡设计包括硬件设计 和软件设计。首先对采集卡的性能和指标进行分析&#xff0c;接着提出硬件的总体设计…

详解知识蒸馏原理和代码

目录 知识蒸馏原理概念技巧举例说明KL 散度及损失 KD训练代码导入包网络架构teacher网络student网络 teacher网络训练定义基本函数训练主函数 student网络训练&#xff08;重点&#xff09;理论部分定义kd的loss定义基本函数训练主函数 绘制结果teacher网络的暗知识softmax_t推…

使用dockerfile自定义Tomcat镜像

一&#xff1a;创建目录 mkdir /root/tomcat chmod 777 /root/ chmod 777 /root/tomcat 或者chmod -R 777 /root 这里的无效选项是因为我想递归修改root目录及root目录文件以下的权限 chmod :-R 递归修改指定目录下所有子目录和文件的权限 二&#xff1a;将jdk和apache压…

RPG游戏自动打怪之朝向判断

RPG游戏辅助想要做到自动打怪 获得到最近怪物信息以后 还需要面向怪物 否则背对怪物等等情况是没有办法攻击以及释放技能的 游戏设计的时候朝向是有很多种情况的 第一种 2D&#xff0c;2.5D老游戏&#xff0c;例如传奇 他的朝向一般是极为固定的4朝向或则8朝向 也就是不…

数组题目总结 -- 花式遍历

目录 一. 反转字符串中的单词思路和代码&#xff1a;I. 博主的做法II. 东哥的做法III. 其他做法1IV. 其他做法2 二. 旋转图像思路和代码&#xff1a;I. 博主的做法II. 东哥的做法 三. 旋转图像&#xff08;逆时针旋转90&#xff09;思路和代码&#xff1a;I. 博主和东哥的做法 …

SpringBoot2-基础入门(一)

SpringBoot2-基础入门&#xff08;一&#xff09; 文章目录 SpringBoot2-基础入门&#xff08;一&#xff09;1. 为什么学习SpringBoot1.1 SpringBoot的优点1.2 SpringBoot的缺点1.3 SpringBoot开发环境 2. 第一个SpringBoot程序2.1 添加依赖2.2 编写主程序类 -- 固定写法2.3 编…

SpringCloud(25):熔断降级实现

熔断降级会在调用链路中某个资源出现不稳定状态时&#xff08;例如调用超时或异常比例升高&#xff09;&#xff0c;对这个资源的调用进行限制&#xff0c;让请求快速失败&#xff0c;避免影响到其它的资源而导致级联错误。当资源被降级后&#xff0c;在接下来的降级时间窗口之…

硅谷新王登国会山,呼吁加强 AI 监管;马斯克任命推特新 CEO;数字媒体巨头申请破产;欧盟通过全球首个全面监管加密资产框架 | 经济学人第 21 周

1. 硅谷新王登国会山&#xff0c;呼吁加强 AI 监管 Sam Altman, the chief executive of OpenAI, the firm behind the ChatGPT chatbot, called for tighter regulation of rapidly developing generative artificial intelligence, such as by forcing disclosure on images …

【文件操作与IO】

目录 一、文件 1、文件的定义 2、File类 &#x1f345;File类中的常见属性 &#x1f345;File类中的构造方法 &#x1f345;File类中的常用方法 二、文件内容的读取-数据流 &#x1f345;InputStream概述 &#x1f345;FileInputStream &#x1f345;OutputStream 概…

真题详解(汇总)-软件设计(八十三)

真题详解&#xff08;include&#xff09;-软件设计&#xff08;八十二)https://blog.csdn.net/ke1ying/article/details/130828203 软件交付后进入维护阶段&#xff0c;采用专门的程序模块对文件或者数据中记录进行增加、删除和修改操作&#xff0c;属于&#xff1f; 解析&a…

Netty重试一定次数后调用System.exit(n)退出应用程序(二)

System.exit()方法 原型&#xff1a;System.exit(int status) 其功能主要是调用Runtime.getRuntime().exit(status); 作用是终止当前正在运行的Java虚拟机&#xff0c;这个status表示退出的状态码&#xff0c;非零表示异常终止。(可以返回给其他进程的调用者一个调用的返回码…

RES 新的数据集 Advancing Referring Expression Segmentation Beyond Single Image 论文笔记

RES 新的数据集 Advancing Referring Expression Segmentation Beyond Single Image 论文笔记 一、Abstract二、引言三、相关工作3.1 Referring Expression Segmentation (RES)3.2 CoSalient Object Detection (CoSOD) 四、提出的方法4.1 概述文本 & 图像编码器TQM & H…

OpenStreetMap实战

介绍 OpenStreetMap&#xff08;OSM&#xff09;是一个由志愿者创建并维护的免费和开源的地图数据库。其目的是为全球任何人提供可自由使用、编辑和分发的地图数据。OpenStreetMap数据库中的地理要素包括道路、建筑、河流、森林、山脉、公共设施等。由于OpenStreetMap是开放的…

数据结构初阶 —— 二叉树链式结构

目录 一&#xff0c;二叉树链式结构 二&#xff0c;二叉树的遍历&#xff08;四种&#xff09; 前序遍历 中序遍历 后序遍历 层序遍历 三&#xff0c;二叉树接口 四&#xff0c;试题 一&#xff0c;二叉树链式结构 普通二叉树的增删查改&#xff0c;意义不大&#xff1b…