JDK11 is coming!

写在前面的话

对于我来说最熟悉的应该是JDK8,对于9和10还没有太了解的时候,11都已经正式发布好久了,JDK的更新速度有点承受不住,幸好11是长期支持的版本,想必也会普及,提前尝鲜,一起学习。

1.JDK11

本次发布的Java 11和2017年9月份发布的Java 9以及 2018年3月份发布的Java 10相比,其最大的区别就是:在长期支持(Long-Term-Support)方面,Oracle表示会对Java 11提供大力支持,这一支持将会持续至2026年9月。这是据 Java 8 以后支持的首个长期版本 JDK11下载地址
从中可以看出,在Java 11之前,Java 9和Java 10是不提供长期支持的,而上一个提供长期支持的版本是Java 8,其将会支持到2025年3月

2.本地变量类型推断

局部变量类型推断,有点像JS,局部变量类型推断就是左边的类型直接使用 var 定义,而不用写具体的类型,编译器能根据右边的表达式自动推断类型,如下:

	var javaversion="JDK11";                 (等同于   String  javaversion="JDK11";)
 	System.out.println(javaversion);
 	结果:JDK11

3.字符串加强

Java 11 增加了一系列的字符串处理方法。

  1. 判断字符串是否为空白:isBlank()
	public boolean isBlank() {
        return indexOfNonWhitespace() == length();
    }	
  1. 去除首尾空格:strip() 去除首部空格:String.stripLeading() 去除尾部空格: String.stripTrailing()
	public String strip() {
        String ret = isLatin1() ? StringLatin1.strip(value)
                                : StringUTF16.strip(value);
        return ret == null ? this : ret;
    }
  1. 复制字符串:repeat(int count)
	public String repeat(int count) {
        if (count < 0) {
            throw new IllegalArgumentException("count is negative: " + count);
        }
        if (count == 1) {
            return this;
        }
        final int len = value.length;
        if (len == 0 || count == 0) {
            return "";
        }
        if (len == 1) {
            final byte[] single = new byte[count];
            Arrays.fill(single, value[0]);
            return new String(single, coder);
        }
        if (Integer.MAX_VALUE / count < len) {
            throw new OutOfMemoryError("Repeating " + len + " bytes String " + count +
                    " times will produce a String exceeding maximum size.");
        }
        final int limit = len * count;
        final byte[] multiple = new byte[limit];
        System.arraycopy(value, 0, multiple, 0, len);
        int copied = len;
        for (; copied < limit - copied; copied <<= 1) {
            System.arraycopy(multiple, 0, multiple, copied, copied);
        }
        System.arraycopy(multiple, 0, multiple, copied, limit - copied);
        return new String(multiple, coder);
    }
  1. 行数:lines()
	public Stream<String> lines() {
        return isLatin1() ? StringLatin1.lines(value)
                          : StringUTF16.lines(value);
    }
    
	var javaversion="JDK11\njava\n".lines().count();
    System.out.print(javasion);
    结果:2

4.集合加强

自 Java 9 开始,Jdk 里面为集合(List/ Set/ Map)都添加了 of 和 copyOf 方法,它们两个都用来创建不可变的集合,来看下它们的使用和区别。
示例1

		var list = List.of("Java", "jdk", "11");
        var copylist = List.copyOf(list);
        System.out.println(list == copylist ); 
        结果:true

示例2

		var listnew = new ArrayList<String>();
        var copylistnew = List.copyOf(list);
        System.out.println(listnew == copylistnew); 
        结果:false

通过分析源码:

static <E> List<E> of(E... elements) {
  switch (elements.length) { // implicit null check of elements
    case 0:
        return ImmutableCollections.emptyList();
    case 1:
        return new ImmutableCollections.List12<>(elements[0]);
    case 2:
        return new ImmutableCollections.List12<>(elements[0], elements[1]);
    default:
        return new ImmutableCollections.ListN<>(elements);
  }
}
static <E> List<E> copyOf(Collection<? extends E> coll) {
    return ImmutableCollections.listCopy(coll);
}
static <E> List<E> listCopy(Collection<? extends E> coll) {
    if (coll instanceof AbstractImmutableList && coll.getClass() != SubList.class) {
        return (List<E>)coll;
    } else {
        return (List<E>)List.of(coll.toArray());
    }
}

可以看出 copyOf 方法会先判断来源集合是不是 AbstractImmutableList 类型的,如果是,就直接返回,如果不是,则调用 of 创建一个新的集合。

示例2因为用的 new 创建的集合,不属于不可变 AbstractImmutableList 类的子类,所以 copyOf 方法又创建了一个新的实例,所以为false.

注意:使用of和copyOf创建的集合为不可变集合,不能进行添加、删除、替换、排序等操作,不然会报 java.lang.UnsupportedOperationException 异常。

上面演示了 List 的 of 和 copyOf 方法,Set 和 Map 接口都有。

5.Stream加强

Stream 是 Java 8 中的新特性。

  1. 增加单个参数构造方法,可为null:
	Stream.ofNullable(null).count(); 
	结果:0
  1. 增加 takeWhile 和 dropWhile 方法:
	Stream.of(1, 2, 3, 2, 1).takeWhile(n -> n < 3).collect(Collectors.toList()); 
	结果:[1,2]
	//从开始计算,当 n < 3 时就截止。
	Stream.of(1, 2, 3, 2, 1).dropWhile(n -> n < 3).collect(Collectors.toList());
	结果:[3,2,1]
	//这个和上面的相反,一旦 n < 3 不成立就开始计算。
  1. iterate重载:
	//这个 iterate 方法的新重载方法,可以让你提供一个 Predicate (判断条件)来指定什么时候结束迭代。
	public class Iterate11 {
    public static void main(String[] args) {
        // 这构造的是无限流 JDK8开始
        Stream.iterate(0, (x) -> x + 1);
        // 这构造的是小于10就结束的流 JDK9开始
        Stream.iterate(0, x -> x < 10, x -> x + 1);
    }
}

6.Optional 加强

Opthonal 也增加了几个非常酷的方法,现在可以很方便的将一个 Optional 转换成一个 Stream, 或者当一个空 Optional 时给它一个替代的。

	Optional.of("java11").orElseThrow(); 
	结果: javastack
	Optional.of("java11").stream().count(); 
	结果: 1
	Optional.ofNullable(null).or(() -> Optional.of("java11")).get(); 
	结果: javastack

7.InputStream 加强

InputStream 终于有了一个非常有用的方法:transferTo,可以用来将数据直接传输到 OutputStream,这是在处理原始数据流时非常常见的一种用法,如下示例(Exception未处理)。

	var classLoader = ClassLoader.getSystemClassLoader();
	var java11= classLoader.getResourceAsStream("java11.txt");
	var jdk11 = File.createTempFile("jdk11", "txt");
	try (var outputStream = new FileOutputStream(javastack)) {
    inputStream.transferTo(outputStream);
	}

8.HTTP Client API

这是 Java 9 开始引入的一个处理 HTTP 请求的的孵化 HTTP Client API,该 API 支持同步和异步,而在 Java 11 中已经为正式可用状态,可以在 java.net 包中找到这个 API。

var request = HttpRequest.newBuilder().uri(URI.create("https://javastack.cn")).GET().build();
var client = HttpClient.newHttpClient();
// 同步
HttpResponse<String> response = client.send(request, HttpResponse.BodyHandlers.ofString());
System.out.println(response.body());
// 异步
client.sendAsync(request, HttpResponse.BodyHandlers.ofString()).thenApply(HttpResponse::body)
.thenAccept(System.out::println);
//上面的 .GET() 可以省略,默认请求方式为 Get!

9.一个命令编译运行源代码

请看代码:

	// 编译
	javac Javastack.java
	// 运行
	java Javastack
	//在我们的认知里面,要运行一个 Java 源代码必须先编译,再运行,两步执行动作。
	//而在未来的 Java 11 版本中,通过一个 java 命令就直接搞定了,如以下所示。
	java Javastack.java

10.17个JEP(JDK Enhancement Proposals,JDK 增强提案)

181:基于嵌套的访问控制(Nest-Based Access Control)
309:动态类文件常量(Dynamic Class-File Constants)
315: 改进 Aarch64 内在函数(Improve Aarch64 Intrinsics)
318:Epsilon:无操作垃圾收集器(Epsilon: A No-Op Garbage Collector)
320:移除Java EE和CORBA模块(Remove the Java EE and CORBA Modules)
321:HTTP客户端(标准)
323:用于 Lambda 参数的局部变量语法(Local-Variable Syntax for Lambda Parameters)
324:Curve25519 和 Curve448 算法的密钥协议(Key Agreement with Curve25519 and Curve448)
327:Unicode 10
328:Flight Recorder
329:ChaCha20 和 Poly1305 加密算法(ChaCha20 and Poly1305 Cryptographic Algorithms)
330:启动单文件源代码程序(Launch Single-File Source-Code Programs)
331:低开销堆分析(Low-Overhead Heap Profiling)
332:传输层安全性(TLS)1.3
333:ZGC:可扩展的低延迟垃圾收集器(实验性)
335:弃用Nashorn JavaScript引擎
336:弃用 Pack200 工具和 API(Deprecate the Pack200 Tools and API)
JDK 详情

如果文章内容有什么问题,或者哪里出错,请及时与我联系。欢迎一起交流。

相关链接

JDK 11 安装指南
https://docs.oracle.com/en/java/javase/11/install/overview-jdk-installation.html#GU-98B9-1FD0B48C346A
JDK 11 发布说明
https://www.oracle.com/technetwork/java/javase/11u-relnotes-5093844.html
JDK 11 官方文档
https://docs.oracle.com/en/java/javase/11/
JDK 11 新特性
https://www.oracle.com/technetwork/java/javase/11-relnote-issues-5012449.html#NewFeature
Java 11 简介
https://blogs.oracle.com/java-platform-group/introducing-java-se-11
Readme
https://www.oracle.com/technetwork/java/javase/documentation/jdk11-readme-5097204.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值