Java21 新特性

文章目录

    • 1. 概述
    • 2. JDK21 安装与配置
    • 3. 新特性
      • 3.1 switch模式匹配
      • 3.2 字符串模板
      • 3.3 顺序集合
      • 3.4 记录模式(Record Patterns)
      • 3.5 未命名类和实例的main方法(预览版)
      • 3.6 虚拟线程

1. 概述


image-20230928232939153

2023年9月19日 ,Oracle 发布了 JDK21,是自 JDK17 之后最新的 LTS 版本(long-term support,长期支持版)。LTS版本一般每两年发布一个,JDK目前的LTS版本有:JDK8 , JDK11 , JDK17 ,JDK21。

Java21新特性:( oracle jdk、openjdk文档)

  • 字符串模板(预览版)
  • 虚拟线程(在JDK19中是预览版,在JDK21中是正式版,会大大改变多线程的编程风格和解决问题的方式)
  • 顺序集合(JDK21引入了SequencedCollection、SequencedSet 、SequencedMap 接口,这些接口提供了在集合开头或结尾处添加、修改或删除元素的方法,以及反转集合的功能)
  • 分代ZGC(属于JVM层面的功能)
  • 记录模式
  • switch的模式匹配
  • 未命名模式和变量(预览版)
  • 未命名类和实例的main方法(预览版)
  • 作用域值(预览版)
  • 矢量API(第六个孵化器)
  • 弃用Windows32位x86端口
  • 禁止代理的动态加载
  • 密钥封装机制的API(引入密钥封装机制 (KEM) 的 API,是一种使用公钥加密来保护对称密钥的加密技术)
  • 结构化并发(预览版, 简化并发编程)
  • 外部函数与内存API(第三次预览版)

2. JDK21 安装与配置


Oracle JDK21 官网下载地址:https://www.oracle.com/java/technologies/downloads/#java21

1、下载 windows 版 oracle jdk,下载地址:https://download.oracle.com/java/21/latest/jdk-21_windows-x64_bin.exe

image-20230928215820796

2、双击刚刚下载好的jdk安装包,进行安装:

image-20230928220157286

image-20230928220338493

image-20230928220503653

3、配置环境变量,在系统变量path中创建新的变量值,变量值的内容就是dk21的安装位置:(偷懒了😈)

系统变量变量值
PathD:\Program Files\Environment\Java\jdk-21

3. 新特性


3.1 switch模式匹配

在Java8中switch可以处理的数据类型有:byte、short、char、int、String、Enum。

而在Java21中switch可以处理更多的类型,会根据类型进行匹配,switch增强版语法如下:

switch(object){case 普通类型 变量名 [when 条件] -> ...; //通过when关键字可以进行条件筛选,[]表示可选语法     case record 类型 变量名 -> ...; // record 记录case enum 类型 变量名 -> ...;case null -> ...;case default -> ...;
}

示例:

package cn.z3inc.jdk21;import java.time.LocalDate;/*** switch 模式匹配** @author 白豆五* @date 2023/9/29* @since JDK21*/
public class SwitchTest {public static void main(String[] args) {test1(new A("HUAWEI Mate 60 Pro"));test2(new B("遥遥领先"));test2(null);test3();}/*** 根据不同的类型去做不同的事情 (jdk21之前的写法)** @param obj 入参的类型*/static void test1(Object obj) {if (obj instanceof A a) { //instanceof 的模式匹配(Java14的新语法,老版本需要强转)System.out.println("类型A===" + a.name);} else if (obj instanceof B b) {System.out.println("类型B===" + b.title);}}/*** 根据不同的类型去做不同的事情 (jdk21:switch的新语法)** @param obj 入参的类型*/static void test2(Object obj) {switch (obj) {//  case 数据类型 变量名 -> 表达式;case A a -> System.out.println("类型A===" + a.name);case B b -> System.out.println("类型B===" + b.title);// case null -> System.out.println("null");// default -> System.out.println("其他类型");case null, default -> System.out.println("其他类型或null"); // 合并写法}}// 静态内部类Astatic class A {String name;public A(String name) {this.name = name;}}// 静态内部类Bstatic class B {String title;public B(String title) {this.title = title;}}/*** 输出当前日期格式为"yyyy-MM-dd"*/static void test3() {LocalDate date = LocalDate.now();System.out.println("date = " + date);String formatted = switch (date.getDayOfWeek()) {case MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY -> "工作日";case SATURDAY, SUNDAY -> "周末";};System.out.println(formatted);}
}

image-20230929165020274


3.2 字符串模板

在Java21之前拼接字符串的写法如下:

方式1:使用 + 拼接字符串

String x = "world"String s = "hello" + x + "Java21!";

方式2:使用StringBuilder拼接字符串

String s = new StringBuilder().append("Hello").append(" ").append("World!").toString();

方式3:使用String的format()或formatted()方法,格式化字符串(有点像c语言的写法)

String name = "旺财";
int age = 18;
char sex = '男';
// 1. String.format():用于格式化字符串
// 参数1: 一个字符串模板 里面包含占位符%xxx"
// 参数2: 替换的值 可变参数
String s = String.format("姓名 %s,年龄 %d,性别 %c", name, age, sex);
System.out.println(s); // 姓名 旺财,年龄 18,性别 男// 2. String.formatted()是Java15新特性,与String.format()功能一样
s = "姓名 %s,年龄 %d,性别 %c".formatted(name, age, sex);
System.out.println(s); // 姓名 旺财,年龄 18,性别 男/*占位符:%s字符串  %d整数  %f浮点数  %c字符  %b布尔值  %t时间%e科学计数法  %x十六进制  %o八进制  %h哈希码  %n换行*/

在Java21中引入字符串模板,在字符串模板中允许在字符串中插入变量或表达式,而无需使用运算符 “+” 拼接字符串,这样可以使字符串拼接操作更加直观和方便。

STR模板处理器:STR是Java平台中的一种模板处理器,用于执行字符串的插值处理。通过STR可以将模板中的占位符或表达式动态替换为对应的值,生成最终的字符串输出。

STR是一个公共静态final字段,会自动导入到每个Java源文件中。

示例:字符串模板快速入门

String s1 = "hello";
String s2 = "world";
String target = STR."\{s1} \{s2}!"; //在字符串模板中使用`\{}`来引用变量
System.out.println(target); // hello world!
target = STR."\{s2}\{s1}";
System.out.println(target);// worldhello

示例:打印99乘法表

package cn.z3inc.jdk21;import static java.lang.StringTemplate.STR;public class StringTemplateTest {public static void main(String[] args) {for (int i = 1; i < 10; i++) {for (int j = 1; j < 10; j++) {if (j > i) {break;}System.out.print(STR."\{j} * \{i} = \{i * j} \t");}System.out.println();}}
}

image-20230929210618078

示例:字符串中嵌入表达式(模板嵌套多了就不太直观了,可以分开写,拒绝套娃😉)

package cn.z3inc.jdk21;import static java.lang.StringTemplate.STR;public class StringTemplateTest {public static void main(String[] args) {String name = "白豆五";String str = STR. "\{isNotBlank(name) ? STR. "\{ name }签到成功" : "签到失败"} " ;System.out.println(str); //白豆五签到成功 }/*** 字符串非空判断** @return 空串返回fale,否则返回true*/public static boolean isNotBlank(String str) {return !(str == null || str.length() == 0);}
}

示例:多行模板表达式(类似python中的多行字符串输出)

package cn.z3inc.jdk21;import static java.lang.StringTemplate.STR;public class StringTemplateTest {public static void main(String[] args) {String title = "假装404";String text = "Hello, world";// 3个双引号代表多行字符串String html = STR. """<html><head><title>\{ title }</title></head><body><p>\{ text }</p></body></html>""" ;System.out.println(html);}
}

image-20230929213801890


3.3 顺序集合

Sequenced Collections

在Java21中引入了全新的SequencedCollection、SequencedSet 、SequencedMap 接口,来表示顺序集合,这些接口提供了在集合开头或结尾处添加、修改或删除元素的方法,以及反转集合的功能。

image-20230929235818750

image-20230929235731060

image-20230929235949547

Java21集合体系结构:

image-20230930002211812

示例:

package cn.z3inc.jdk21;
import java.util.ArrayList;
import java.util.SequencedCollection;public class SequencedCollectionsTest {public static void main(String[] args) {SequencedCollection<String> list = new ArrayList<>();list.add("b");list.addLast("c");list.addFirst("a");// 倒序遍历for (String s : list.reversed()) {System.out.println(s);}}
}

image-20230930004113685


3.4 记录模式(Record Patterns)

类似JS中的对象参数解构赋值,把Java中的Record对象拆解成多个变量。

Record类适用场景:

  • 作为数据载体,如 DTO,VO等
  • 相对于属性可变的普通pojo,Record对象更适合函数式编程。

示例:Record 快速入门

package cn.z3inc.jdk21;//  老师类 record类型
public record Teacher(String name, int age) {  
}/*
//record类的源码:
public final class Teacher extends java.lang.Record {// 字段初始化后不可变private final String name;private final int age;// 带参构造器public Teacher(String name, int age) {this.name = name;this.age = age;}//提供两个get方法public String name() {return name;}public int age() {return age;}@Overridepublic boolean equals(Object obj) {if (obj == this) return true;if (obj == null || obj.getClass() != this.getClass()) return false;var that = (Teacher) obj;return Objects.equals(this.name, that.name) &&this.age == that.age;}@Overridepublic int hashCode() {return Objects.hash(name, age);}@Overridepublic String toString() {return "Teacher[" +"name=" + name + ", " +"age=" + age + ']';}
}*/
package cn.z3inc.jdk21;/*** 测试 记录模式* @author 白豆五* @date 2023/9/30* @since JDK21*/
public class RecordTest {public static void main(String[] args) {Teacher teacher = new Teacher("张三", 18);System.out.println(teacher);System.out.println("name:"+teacher.name());System.out.println("age:"+teacher.age());System.out.println("equals:"+teacher.equals(new Teacher("张三", 18)));System.out.println("hashCode:"+teacher.hashCode());System.out.println("toString:"+teacher.toString());}
}

image-20230930012706946

示例2:

package cn.z3inc.jdk21;// 老师类 记录类型
public record Teacher(String name, int age) {  
}
package cn.z3inc.jdk21;import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;/*** 需求: 把老师数据转成java对象,保留20岁以上的老师,姓相同的分到一组** @author 白豆五* @date 2023/9/30* @since JDK21*/
public class RecordTest2 {public static void main(String[] args) {// 1. 模拟excel表格数据String cvs = """张三,23李四,20王五,19赵六,18张富贵,22李狗蛋,15                                         """;// 2. 按行切割字符串String[] splitArr = cvs.split("\n");// 3. 通过stream流处理数据Map<Character, List<Teacher>> map = Arrays.stream(splitArr)// 3.1. 把每一行数据转成Teacher对象.map(line -> {String[] split = line.split(",");return new Teacher(split[0], Integer.parseInt(split[1]));})// 3.2. 过滤掉年龄小于20岁的老师.filter(teacher -> teacher.age() >= 20)// 3.3. 按姓氏分组.collect(Collectors.groupingBy(teacher -> teacher.name().charAt(0)));System.out.println(map);}
}

image-20230930015837853

示例3:

package cn.z3inc.jdk21;/*** 测试 记录模式* @author 白豆五* @date 2023/9/30* @since JDK21*/
public class RecordTest3 {public static void main(String[] args) {print2(new Teacher("张三", 23));}/*** 传统方式写法** @param o*/@Deprecatedstatic void print(Object o) {if (o instanceof Teacher) {Teacher t = (Teacher) o;System.out.println("name:" + t.name() + " ,age:" + t.age());}}/*** 记录模式写法* @param o*/static void print2(Object o) {if (o instanceof Teacher(String name, int age)) { //解构记录对象中的值System.out.println("name:" + name + " ,age:" + age);}}
}

image-20230930021423829


3.5 未命名类和实例的main方法(预览版)

可以写类名,也可以不写类名。

image-20230930022047663

编译:

javac --release 21 --enable-preview MainTest.java

image-20230930022552725

运行:

java --enable-preview MainTest

image-20230930022958540


3.6 虚拟线程


todo

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

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

相关文章

电子计算机核心发展(继电器-真空管-晶体管)

目录 继电器 最大的机电计算机之一——哈弗Mark1号&#xff0c;IBM1944年 背景 组成 性能 核心——继电器 简介 缺点 速度 齿轮磨损 Bug的由来 真空管诞生 组成 控制开关电流 继电器对比 磨损 速度 缺点 影响 代表 第一个可编程计算机 第一个真正通用&am…

使用晶体管做布尔逻辑和逻辑门

目录 二进制&#xff0c;三进制&#xff0c;五进制 true&#xff0c;false表示0&#xff0c;1 早期计算机采用进制 布尔逻辑 三个基本操作&#xff1a;NOT,AND,OR 基础“真值表” NOT 如何实现&#xff1f; AND如何实现&#xff1f; OR如何实现&#xff1f; 图标表示…

LLM之Colossal-LLaMA-2:Colossal-LLaMA-2的简介、安装、使用方法之详细攻略

LLM之Colossal-LLaMA-2&#xff1a;Colossal-LLaMA-2的简介、安装、使用方法之详细攻略 导读&#xff1a;2023年9月25日&#xff0c;Colossal-AI团队推出了开源模型Colossal-LLaMA-2-7B-base。Colossal-LLaMA-2项目的技术细节&#xff0c;主要核心要点总结如下: >> 数据处…

数据分析方法:RFM模型

一、RFM基本原理 RFM是三个单词的缩写&#xff1a; 最近一次消费时间&#xff08;Recency&#xff09;&#xff0c;取数的时候一般取最近一次消费记录到当前时间的间隔&#xff0c;比如&#xff1a;7天、30天、90天未到店消费&#xff1b;直观上&#xff0c;一个用户太久不到…

【计算机组成原理】考研真题攻克与重点知识点剖析 - 第 1 篇:计算机系统概述

前言 本文基础知识部分来自于b站&#xff1a;分享笔记的好人儿的思维导图&#xff0c;感谢大佬的开源精神&#xff0c;习题来自老师划的重点以及考研真题。此前我尝试了完全使用Python或是结合大语言模型对考研真题进行数据清洗与可视化分析&#xff0c;本人技术有限&#xff…

由于计算机中丢失msvcp110.dll的解决方法与msvcp110.dll丢失修复方法

相信大家在打开电脑软件或许游戏都有遇到过电脑提示找不到msvcp110.dll文件&#xff0c;导致软件游戏打不开&#xff0c;我们应该怎么办&#xff1f;不用着急&#xff0c;今天小编我分享我找了很久成功解决问题的方法给大家&#xff0c;希望可以帮到各位。 1. 使用DLL修复工具&…

【VR】【unity】如何在VR中实现远程投屏功能?

【背景】 目前主流的VD应用,用于娱乐很棒,但是用于工作还是无法效率地操作键鼠。用虚拟键盘工作则显然是不现实的。为了让自己的头显能够起到小面积代替多显示屏的作用,自己动手开发投屏VR应用。 【思路】 先实现C#的投屏应用。研究如何将C#投屏应用用Unity 3D项目转写。…

pandas

一、pandas初级 安装matplotlib:pip install matplotlib 安装pandas:pip install pandas 本地C:\Users\Administrator\pip&#xff0c;在此目录配置清华园的远程下载 配置内容&#xff1a; [global] index-urlhttps://pypi.tuna.tsinghua.edu.cn/simple [install] trusted-ho…

WebSocket实战之五JSR356

一、前言 前几篇WebSocket例子服务端我是用NodeJS实现,这一篇我们用Java来搭建一个WebSocket服务端&#xff0c;从2011年WebSocket协议RFC6455发布后&#xff0c;大多数浏览器都实现了WebSocket协议客户端的API,而对于服务端Java也定义了一个规范JSR356,即Java API for WebSoc…

华为云云耀云服务器L实例评测|搭建CounterStrike Source Delicated Server(CS起源游戏服务器)

华为云云耀云服务器L实例评测&#xff5c;搭建CounterStrike Source Delicated Server&#xff08;CS起源游戏服务器&#xff09; #【有奖征文】华为云云服务器焕新上线&#xff0c;快来亲身感受评测吧&#xff01;# ⭐️ CounterStrikeSource&#xff08;CS起源是Valve的一款…

windows系统利用powershell查看系统支持那些Windows功能选项

在PowerShell中&#xff0c;我们可以使用Get-WindowsOptionalFeature cmdlet命令来查看Windows功能选项。 打开PowerShell 输入以下命令&#xff1a;将结果输出到1.log Get-WindowsOptionalFeature -Online >1.log 可以看到在指定路径下看到生成了文件 打开查看内容&…

jvm 参数配置

查看当前jvm配置参数的值 jsp查看所有的jvm端口 jinfo -flag 参数(XX:后面的) JIT配置 -XX:CompileThreshold在方法调用的默认阈值在客户端1500次&#xff0c;在服务器端10000次。 -XX:-UseCounterDecay用来关闭热度衰减。 -XX:CounterHalfLifeTime设置半衰减的时间&#x…

辅助驾驶功能开发-测试篇(2)-真值系统介绍

1 真值系统概述 1.1 真值评测系统核心应用 快速构建有效感知真值,快速完成感知性能评估,快速分析感知性能缺陷。 主要应用场景包括: 1. 感知算法开发验证: 在算法开发周期中,评测结果可以作为测试报告的一部分,体现算法性能的提升。 2. 遴选供应…

基于SpringBoot+MyBatis实现的个人博客系统(一)

这篇主要讲解一下如何基于SpringBoot和MyBatis技术实现一个简易的博客系统(前端页面主要是利用CSS,HTML进行布局书写),前端的静态页面代码可以直接复制粘贴,后端的接口以及前端发送的Ajax请求需要自己书写. 博客系统需要完成的接口: 注册登录博客列表页展示博客详情页展示发布博…

九、2023.10.3.Linux(end).9

文章目录 33、简述mmap的原理和使用场景&#xff1f;34、互斥量能不能在进程中使用&#xff1f;35、协程是轻量级线程&#xff0c;轻量级表现在哪里&#xff1f;36、说说常见信号有哪些&#xff0c;表示什么含义&#xff1f;37、说说线程间通信的方式有哪些&#xff1f;38、说说…

C# 自定义控件库之Lable组合控件

1、创建类库 2、在类库中添加用户控件&#xff08;Window窗体&#xff09; 3、控件视图 4、后台代码 namespace UILib {public partial class DeviceInfoV : UserControl{public DeviceInfoV(){InitializeComponent();ParameterInitialize();}#region 初始化private void Par…

初级篇—第二章SELECT查询语句

文章目录 什么是SQLSQL 分类SQL语言的规则与规范阿里巴巴MySQL命名规范数据导入指令 显示表结构 DESC基本的SELECT语句SELECTSELECT ... FROM列的别名 AS去除重复行 DISTINCT空值参与运算着重号查询常数过滤数据 WHERE练习 运算符算术运算符加减符号乘除符号取模符号 符号比较运…

DevSecOps 将会嵌入 DevOps

通常人们在一个项目行将结束时才会考虑到安全&#xff0c;这么做会导致很多问题&#xff1b;将安全融入到DevOps的工作流中已产生了积极结果。 DevSecOps&#xff1a;安全正当时 一直以来&#xff0c;开发人员在构建软件时认为功能需求优先于安全。虽然安全编码实践起着重要作…

python——Django框架

一、基本介绍 Django 是一个由 Python 编写的一个开放源代码的 Web 应用框架。 使用 Django&#xff0c;只要很少的代码&#xff0c;Python 的程序开发人员就可以轻松地完成一个正式网站所需要的大部分内容&#xff0c;并进一步开发出全功能的 Web 服务 Django 本身基于 MVC …

踩坑笔记 MySQL分页排序查询(Order by limit)导致数据丢失和重复

文章目录 背景现象原因解决方案 背景 分页查询排序后的数据&#xff0c;是一个非常常见的业务场景&#xff1b;但当使用不唯一的字段排序时&#xff0c;分两页查询的数据可能出现数据重复和丢失的错觉。 在执行查询时&#xff0c;MySQL会根据查询优化器的决策来确定数据的检索…