面试官问我Java9~14的有哪些重要的新特性,我哭了~~~( 四 )

  • 飞行记录器:飞行记录器之前是商业版 JDK 的一项分析工具 , 但在 Java 11 中 , 其代码被包含到公开代码库中 , 这样所有人都能使用该功能了
  • Java12增强 Switch
    • 传统的 switch 语法存在容易漏写 break 的问题 , 而且从代码整洁性层面来看 , 多个 break 本质也是一种重复
    • Java12 提供了 swtich 表达式 , 使用类似 lambda 语法条件匹配成功后的执行块 , 不需要多写 break
    • 作为预览特性加入 , 需要在javac编译和java运行时增加参数--enable-preview switch (day) { case MONDAY, FRIDAY, SUNDAY -> System.out.println(6); case TUESDAY -> System.out.println(7); case THURSDAY, SATURDAY -> System.out.println(8); case WEDNESDAY -> System.out.println(9); }
    数字格式化工具类
    • NumberFormat 新增了对复杂的数字进行格式化的支持 NumberFormat fmt = NumberFormat.getCompactNumberInstance(Locale.US, NumberFormat.Style.SHORT); String result = fmt.format(1000); System.out.println(result); // 输出为 1K , 计算工资是多少K更方便了 。。。
    Shenandoah GC
    • Redhat 主导开发的 Pauseless GC 实现 , 主要目标是 99.9% 的暂停小于 10ms , 暂停与堆大小无关等
    • 和 Java11 开源的 ZGC 相比(需要升级到 JDK11 才能使用) , Shenandoah GC 有稳定的 JDK8u 版本 , 在 Java8 占据主要市场份额的今天有更大的可落地性
    G1 收集器提升
    • Java12 为默认的垃圾收集器 G1 带来了两项更新: 可中止的混合收集集合:JEP344 的实现 , 为了达到用户提供的停顿时间目标 , JEP 344 通过把要被回收的区域集(混合收集集合)拆分为强制和可选部分 , 使 G1 垃圾回收器能中止垃圾回收过程 。G1 可以中止可选部分的回收以达到停顿时间目标 及时返回未使用的已分配内存:JEP346 的实现 , 增强 G1 GC , 以便在空闲时自动将 Java 堆内存返回给操作系统
    Java13引入 yield 关键字到 Switch 中
    • Switch 表达式中就多了一个关键字用于跳出 Switch 块的关键字 yield , 主要用于返回一个值
    • yield和 return 的区别在于:return 会直接跳出当前循环或者方法 , 而 yield 只会跳出当前 Switch 块 , 同时在使用 yield 时 , 需要有 default 条件 private static String descLanguage(String name) { return switch (name) { case "Java": yield "object-oriented, platform independent and secured"; case "Ruby": yield "a programmer's best friend"; default: yield name +" is a good language"; }; }
    文本块
    • 解决 Java 定义多行字符串时只能通过换行转义或者换行连接符来变通支持的问题 , 引入三重双引号来定义多行文本
    • 两个"""中间的任何内容都会被解释为字符串的一部分 , 包括换行符 String json ="{\n" + " \"name\":\"mkyong\",\n" + " \"age\":38\n" + "}\n"; // 未支持文本块之前 String json = """ { "name":"mkyong", "age":38 } """;
    增强 ZGC 释放未使用内存
    • 在 Java 11 中是实验性的引入的 ZGC 在实际的使用中存在未能主动将未使用的内存释放给操作系统的问题
    • ZGC 堆由一组称为 ZPages 的堆区域组成 。 在 GC 周期中清空 ZPages 区域时 , 它们将被释放并返回到页面缓存 ZPageCache 中 , 此缓存中的 ZPages 按最近最少使用(LRU)的顺序 , 并按照大小进行组织
    • 在 Java 13 中 , ZGC 将向操作系统返回被标识为长时间未使用的页面 , 这样它们将可以被其他进程重用
    SocketAPI 重构