• 「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」
  • 当然 不论新老朋友 我相信您都可以 从中获益。如果觉得 「不错」 的朋友,欢迎 「关注 + 留言 + 分享」,文末有完整的获取链接,您的支持是我前进的最大的动力!

特性总览

以下是 Java 12 中的引入的部分新特性。关于 Java 12 新特性更详细的介绍可参考这里

JVM 更改:

  • Shenandoah:低暂停时间的垃圾收集器-实验性(JEP 189)
  • 及时从 G1 返回未使用的已提交内存(JEP 346)
  • 可中止的 G1 混合收集(JEP 344)
  • Mincrobenchmark 套件(JEP 230)
  • 一个 AArch64 端口,而不是两个(JEP 340)
  • 默认 CDS 存档(JEP 341)

语言更改和特性:

  • Switch 表达式-预览(JEP 325)
  • Teeing Collectors
  • 字符串新方法
  • JVM 常量 API(JEP 334)
  • instanceof 的模式匹配-预览(JEP 305)
  • File.mismatch 方法
  • 紧凑的数字格式

一. Shenandoah:低暂停时间垃圾收集器-实验性(JEP 189)

Shenandoah 是一种新的低暂停和并发垃圾回收器,它减少了GC暂停时间,并且与 Java 堆大小无关(5M 或 5G 的堆大小具有相同的暂停时间,对于大型堆应用程序很有用,请阅读此 研究论文)。

该 GC 是一项实验性功能,我们需要使用以下选项来启用新的 Shenandoah GC。

-XX:+UnlockExperimentalVMOptions -XX:+UseShenandoahGC

但是,Oracle JDK 和 OpenJDK 均不包含此新的 Shenandoah GC

C:\Users\wmyskxz> java -version
java version "12" 2019-03-19
Java(TM) SE Runtime Environment (build 12+33)
Java HotSpot(TM) 64-Bit Server VM (build 12+33, mixed mode, sharing) C:\Users\wmyskxz> java -XX:+UnlockExperimentalVMOptions -XX:+UseShenandoahGC
Error occurred during initialization of VM
Option -XX:+UseShenandoahGC not supported

AdoptOpenJDK 12 可能包含这种新型的 GC,感兴趣的童鞋可以自行下载体验。

进一步阅读:Shenandoah OpenJDK 主页 - https://openjdk.java.net/projects/shenandoah/

二. 及时从 G1 返回未使用的已提交内存(JEP 346)

该 JEP 提高了垃圾优先(G1)收集器的性能。如果应用程序的活动少或处于空闲状态,则 G1 定期触发并发周期,以确定总体 Java 堆使用情况,并将未使用的 Java 堆内存返回给操作系统。

三. 可中止的G1混合收集(JEP 344)

G1 效率的提高包括:如果 G1 混合收集可能超出定义的暂停目标,则可以将其中止。这是通过将混合集合划分为强制性和可选性来实现的。

因此,G1 收集器可以优先考虑首先收集强制性集合,以满足暂停时间目标。

四. Mincrobenchmark 套件(JEP 230)

JDK 源代码中添加了一系列 Java Microbenchmark Harness(JMH)基准测试,对于那些有兴趣添加或修改 JDK 源代码本身的用户,现在他们可以比较性能了。

五. 一个 AArch64 端口,而不是两个(JEP 340)

在 Java 12 之前,64 位 ARM体系结构 有两个不同的源代码或端口。

  • Oracle– src/hotspot/cpu/arm
  • Red Hat?– src/hotspot/cpu/aarch64

Java 12 删除了 Oracle src/hotspot/cpu/arm 端口,仅保留了一个端口 src/hotspot/cpu/aarch64,并将 aarch64 其作为 64 位 ARM 体系结构的默认构建。

六. 默认 CDS 存档(JEP 341)

类数据共享(Class-Data-Sharing)是在 JDK 5 引入的,允许将一组类预处理成共享的归档文件,然后在运行时对其进行内存映射,以减少启动时间,这还可以在多个 JVM 共享相同的归档文件时减少动态内存占用的功能。

在 Java 12 之前,我们需要 -Xshare: dump 用于为 JDK 类生成 CDS 存档文件。在 Java 12 中,目录中有一个新 classes.jsa 文件,这是 /bin/server/ JDK类的默认 CDS 存档文件。

从 Java 12 开始,默认情况下 CSD 为 ON。要在CDS关闭的情况下运行程序,请执行以下操作:

java -Xshare:off HelloWorld.java

七. Switch 表达式-预览(JEP 325)

传统的 switch 语句,我们可以通过将值分配给变量来返回值:

private static String getText(int number) {
String result = "";
switch (number) {
case 1, 2:
result = "one or two";
break;
case 3:
result = "three";
break;
case 4, 5, 6:
result = "four or five or six";
break;
default:
result = "unknown";
break;
};
return result;
}

在 Java 12 中,我们可以使用 breakcase L -> 从开关返回值。

private static String getText(int number) {
String result = switch (number) {
case 1, 2:
break "one or two";
case 3:
break "three";
case 4, 5, 6:
break "four or five or six";
default:
break "unknown";
};
return result;
}

case L -> 语法:

private static String getText(int number) {
return switch (number) {
case 1, 2 -> "one or two";
case 3 -> "three";
case 4, 5, 6 -> "four or five or six";
default -> "unknown";
};
}

要启用 Java 12 预览功能需要按以下操作进行:

javac --enable-preview --release 12 Example.java
java --enable-preview Example

注意:此开关表达式 Java 13 中具有第二个预览(break 改成 yield),并在 Java 14 中成为标准功能;

八. Teeing Collectors

Teeing Collector 是 Streams API 中引入的新的收集器实用程序。

该收集器具有三个参数——两个收集器和一个 Bi 函数。所有输入值都传递给每个收集器,结果交给 Bi 函数使用。(为了大家便于理解,我画了一个图)

典型的例子就是求取一个平均值:(当然对于这个例子,我们可以使用 averagingInt() 来完成...)

double average = Stream.of(1, 2, 3, 4, 5)
.collect(Collectors.teeing(
summingDouble(i -> i),
counting(),
(sum, n) -> sum / n));
System.out.println(average); // 输出 3.0

九. 字符串新方法

indent(int)-缩进

此方法根据输入参数 'n' 的值调整字符串中每行的缩进量,并规范行终止符。

  • 如果 n > 0,则在每行的开头插入 n 个空格(U + 0020)。
  • 如果 n < 0,则从每行开头最多删除 n 个空格字符。如果给定的行没有足够的空格,那么将删除所有前导空格字符。制表符也被视为单个字符。
  • 如果 n = 0,则该行保持不变。但是,行终止符仍被标准化。

下面是使用 JShell 调用的演示:

jshell> String str = "******\n   Hi\n  How are you?\n******"
str ==> "******\n Hi\n How are you?\n******" jshell> str.indent(0)
$23 ==> "******\n Hi\n How are you?\n******\n" jshell> str.indent(3)
$24 ==> " ******\n Hi\n How are you?\n ******\n" jshell> str.indent(-2)
$25 ==> "******\n Hi\nHow are you?\n******\n" jshell>

注意,使用 indent() 方法时,\r 会被转化为 \n

transform(Function<? super String,? extends R> f)

此方法使我们可以在给定的字符串上调用函数。该函数应该期望一个 String 参数,并产生一个 R 结果。

下面是使用 transform() 方法把 CSV 字符串转换为字符串列表的演示:

jshell> String str = "Hi,Hello,Wmyskxz";
str ==> "Hi,Hello,Wmyskxz" jshell> var strList = str.transform(s -> {return Arrays.asList(s.split(","));});
strList ==> [Hi, Hello, Wmyskxz] jshell>

Optional describeConstable()

Java 12 在 JEP 334 中 引入了 Constants API 。如果您查看 String 类文档,它将实现 Constants API 的两个新接口——Constable 和 ConstantDesc。此方法在 Constable 接口中声明,并在 String 类中实现。

此方法返回一个 Optional,其中包含该实例的名义描述符,即实例本身。

jshell> String str = "wmyskxz";
str ==> "wmyskxz" jshell> var s = str.describeConstable();
s ==> Optional[wmyskxz] jshell> s.get()
$30 ==> "wmyskxz" jshell>

String resolveConstantDesc(MethodHandles.Lookup lookup)

此方法是 Constants API 的一部分,并在 ConstantDesc 接口中声明。它将实例解析为 ConstantDesc,其结果就是实例本身。

shell> import java.lang.invoke.MethodHandles;

jshell> String str = "Hello";
str ==> "Hello" jshell> str.resolveConstantDesc(MethodHandles.lookup());
$18 ==> "Hello" jshell>

十. JVM 常量 API(JEP 334)

此 JEP 引入了一个新软件包 java.lang.constant。对于不使用常量池的开发人员来说,这没什么用。

进一步阅读:官方文档 - https://docs.oracle.com/en/java/javase/12/docs/api/java.base/java/lang/constant/package-summary.html

十一. instanceof 的模式匹配-预览(JEP 305)

另一个预览语言功能。将一个类型转换为另一种类型的旧方法是:

if (obj instanceof String) {
String s = (String) obj;
// use s in your code from here
}

新方法是:

if (obj instanceof String s) {
// can use s directly here
}

这为我们节省了一些不必要的类型转换。

十二. File.mismatch 方法

Java 12 添加了以下方法来比较两个文件:

public static long mismatch(Path path, Path path2) throws IOException

此方法返回第一个不匹配的位置,如果没有不匹配,则返回 -1L

在以下情况下,两个文件可能不匹配:

  • 如果字节不相同。在这种情况下,将返回第一个不匹配字节的位置。
  • 文件大小不相同。在这种情况下,将返回较小文件的大小。

下面给出了示例代码片段:(摘录自 JournalDev)

import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path; public class FileMismatchExample { public static void main(String[] args) throws IOException {
Path filePath1 = Files.createTempFile("file1", ".txt");
Path filePath2 = Files.createTempFile("file2", ".txt");
Files.writeString(filePath1,"JournalDev Test String");
Files.writeString(filePath2,"JournalDev Test String"); long mismatch = Files.mismatch(filePath1, filePath2); System.out.println("File Mismatch position... It returns -1 if there is no mismatch"); System.out.println("Mismatch position in file1 and file2 is >>>>");
System.out.println(mismatch); filePath1.toFile().deleteOnExit();
filePath2.toFile().deleteOnExit(); System.out.println(); Path filePath3 = Files.createTempFile("file3", ".txt");
Path filePath4 = Files.createTempFile("file4", ".txt");
Files.writeString(filePath3,"JournalDev Test String");
Files.writeString(filePath4,"JournalDev.com Test String"); long mismatch2 = Files.mismatch(filePath3, filePath4); System.out.println("Mismatch position in file3 and file4 is >>>>");
System.out.println(mismatch2); filePath3.toFile().deleteOnExit();
filePath4.toFile().deleteOnExit();
}
}

编译并运行上述 Java 程序时,输出为:

十三. 紧凑的数字格式

实例代码:

import java.text.NumberFormat;
import java.util.Locale; public class CompactNumberFormatting { public static void main(String[] args)
{
System.out.println("Compact Formatting is:");
NumberFormat upvotes = NumberFormat
.getCompactNumberInstance(new Locale("en", "US"), NumberFormat.Style.SHORT);
upvotes.setMaximumFractionDigits(1); System.out.println(upvotes.format(2592) + " upvotes"); NumberFormat upvotes2 = NumberFormat
.getCompactNumberInstance(new Locale("en", "US"), NumberFormat.Style.LONG);
upvotes2.setMaximumFractionDigits(2);
System.out.println(upvotes2.format(2011) + " upvotes");
}
}

输出:

Compact Formatting is:
2.6k upvotes
2.01 thousand upvotes

参考资料

  1. OpenJDK 官方说明 - http://openjdk.java.net/projects/jdk/12/
  2. What is new in Java 12 - https://mkyong.com/java/what-is-new-in-java-12/
  3. Java 12 Features | JournalDev - https://www.journaldev.com/28666/java-12-features
  4. 39 New Features(and APIs) in JDK 12 - https://dzone.com/articles/39-new-features-and-apis-in-jdk-12

文章推荐

  1. 这都JDK15了,JDK7还不了解? - https://www.wmyskxz.com/2020/08/18/java7-ban-ben-te-xing-xiang-jie/
  2. 全网最通透的 Java 8 版本特性讲解 - https://www.wmyskxz.com/2020/08/19/java8-ban-ben-te-xing-xiang-jie/
  3. Java9的这些史诗级更新你都不知道? - https://www.wmyskxz.com/2020/08/20/java9-ban-ben-te-xing-xiang-jie/
  4. 你想了解的 JDK 10 版本更新都在这里 - https://www.wmyskxz.com/2020/08/21/java10-ban-ben-te-xing-xiang-jie/
  5. 这里有你不得不了解的 Java 11 特性 - https://www.wmyskxz.com/2020/08/22/java11-ban-ben-te-xing-xiang-jie/
  6. 「MoreThanJava」系列文集 - https://www.wmyskxz.com/categories/MoreThanJava/
  • 本文已收录至我的 Github 程序员成长系列 【More Than Java】,学习,不止 Code,欢迎 star:https://github.com/wmyskxz/MoreThanJava
  • 个人公众号 :wmyskxz,个人独立域名博客:wmyskxz.com,坚持原创输出,下方扫码关注,2020,与您共同成长!

非常感谢各位人才能 看到这里,如果觉得本篇文章写得不错,觉得 「我没有三颗心脏」有点东西 的话,求点赞,求关注,求分享,求留言!

创作不易,各位的支持和认可,就是我创作的最大动力,我们下篇文章见!

Java12版本特性【一文了解】的更多相关文章

  1. Java14版本特性【一文了解】

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

  2. 为什么说JAVA中要慎重使用继承 C# 语言历史版本特性(C# 1.0到C# 8.0汇总) SQL Server事务 事务日志 SQL Server 锁详解 软件架构之 23种设计模式 Oracle与Sqlserver:Order by NULL值介绍 asp.net MVC漏油配置总结

    为什么说JAVA中要慎重使用继承   这篇文章的主题并非鼓励不使用继承,而是仅从使用继承带来的问题出发,讨论继承机制不太好的地方,从而在使用时慎重选择,避开可能遇到的坑. JAVA中使用到继承就会有两 ...

  3. C# 语言历史版本特性(C# 1.0到C# 7.1汇总更新) C#各版本新特性 C#版本和.NET版本以及VS版本的对应关系

    C# 语言历史版本特性(C# 1.0到C# 7.1汇总更新) 2017年08月06日 11:53:13 阅读数:6705 历史版本 C#作为微软2000年以后.NET平台开发的当家语言,发展至今具有1 ...

  4. Java12新特性 -- 默认生成类数据共享(CDS)归档文件

    默认生成类数据共享(CDS)归档文件 同一个物理机/虚拟机上启动多个JVM时,如果每个虚拟机都单独装载自己需要的所有类,启动成本和内 存占用是比较高的.所以Java团队引入了类数据共享机制 (Clas ...

  5. Python 如何移除旧的版本特性,如何迎接新的特性?

    2020 年 4 月 20 日,Python 2 的最后一个版本 2.7.18 发布了,这意味着 Python 2 是真正的 EOL(end of life)了,一个时代终于落幕了. Python 2 ...

  6. 什么?Java9这些史诗级更新你都不知道?Java9特性一文打尽!

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

  7. Android各版本特性

    此篇文章可以利用碎片化时间进行消化和了解,针对Android各个版本特性,并没有把所有列出,只是抽出了比较常用重要的特性作为提示,同时在面试中只要牢记重要的几个点即可,其他特性直接查找官方文档即可. ...

  8. [转帖]sql server版本特性简介、版本介绍简介

    sql server版本特性简介.版本介绍简介 https://www.cnblogs.com/gered/p/10986240.html 目录 1.1.sql server的版本信息 1.2.版本重 ...

  9. Java 面试知识点解析(四)——版本特性篇

    前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...

  10. 【JAVA各版本特性】JAVA 1.0 - JAVA 12

    make JDK Version 1.01996-01-23 Oak(橡树) 初代版本,伟大的一个里程碑,但是是纯解释运行,使用外挂JIT,性能比较差,运行速度慢. JDK Version 1.119 ...

随机推荐

  1. NVME(学习笔记四)—概念解读

    1. 综述 NVMe over PCIe协议,定义了NVMe协议的使用范围.指令集.寄存器配置规范等. 名词解释 1.1.1 Namespace Namespace是一定数量逻辑块(LB)的集合,属性 ...

  2. java 注解结合 spring aop 自动输出日志新增拦截器与过滤器

    auto-log auto-log 是一款为 java 设计的自动日志监控框架. 前面已经写过了两篇: java 注解结合 spring aop 实现自动输出日志 java 注解结合 spring a ...

  3. 《深入理解Java虚拟机》(六) 调优策略 -- 笔记

    目录 一.操作文档类功能,大量大对象直接进入老年代 问题现象 解决方法 通过单一Java虚拟机管理大量的内存 同一台服务器上部署若干Java虚拟机 二.异步请求大量累积 三.排查问题 排查问题: 可能 ...

  4. C++ 线程的学习---线程死锁

      因为是学习篇,写下是为了个人的学习与理解.故参考其他文章为多. 为什么会有死锁?           想象一下这样的情况,thread A 在run的时候需要等待thread B的结果,也就是th ...

  5. 使用3-hexo主题时无法正常渲染html代码

    问题描述 在hexo框架中使用3-hexo主题时,会遇到这样一个问题:在markdown中嵌入html代码,这些嵌入的html代码无法正常显示. 原因分析 在使用3-hexo主题时,默认使用主题自带的 ...

  6. Xray安全评估工具使用

    xray 是一款功能强大的安全评估工具,主要特性有: 检测速度快.发包速度快; 漏洞检测算法高效. 支持范围广.大至 OWASP Top 10 通用漏洞检测,小至各种 CMS 框架 POC,均可以支持 ...

  7. WSL2镜像文件压缩

    WSL2的镜像文件(*.vhdx)支持自动扩容,但是一般不会自动缩容.一旦某次存放过大文件以后,即使后续删除,镜像文件体积仍然不会缩小,导致大量磁盘空间浪费.因此,可以定期对镜像文件进行手动压缩. 镜 ...

  8. 项目实战:Qt+Android模拟操作器(模拟操作app,打开,点击,输入,获取验证码等等)

    若该文为原创文章,转载请注明原文出处本文章博客地址:https://blog.csdn.net/qq21497936/article/details/109313803各位读者,知识无穷而人力有穷,要 ...

  9. Spring Boot+Thymeleaf+MyBatis--推荐一个后端练手极佳的商城项目

    项目整体架构 newbee-mall ├── src/main/java └── ltd.newbee.mall ├── common // 存放相关的常量配置及枚举类 ├── config // 存 ...

  10. Linux操作系统加固建议

    1.1.1 口令锁定策略 1.执行备份 (1).redhat执行备份: #cp -p /etc/pam.d/system-auth /etc/pam.d/system-auth_bak (2).SUS ...