美国时间 09 月 25 日,oralce 正式发布了 java 11,这是据 java 8 以后支持的首个长期版本。非常值得大家的关注,可以通过下面的地址进行下载:
https://www.oracle.com/technetwork/java/javase/downloads/jdk11-downloads-5066655.html
为什么说是长期版本,看下面的官方发布的支持路线图表。
可以看出 java 8 扩展支持到 2025 年,而 java 11 扩展支持到 2026 年。
现在大部分都在用 java 8,java 9 和 10 目前很少有人在用,至少我没有发现有公司在生产环境应用的,那就是找死。
现在 java 11 长期支持,也已经包含了 9 和 10 的全部功能,9 和 10 自然就活到头了。。
那么我们来看下 从 java 9 - 11 都有哪些重要的新特性呢?
1、本地变量类型推断
这个博主已经写过一篇文章,详细的介绍了 java 10 带来的这个新特性。
什么是局部变量类型推断?
1
2
|
var javastack = "javastack" ; system.out.println(javastack); |
大家看出来了,局部变量类型推断就是左边的类型直接使用 var 定义,而不用写具体的类型,编译器能根据右边的表达式自动推断类型,如上面的 string 。
1
|
var javastack = "javastack" ; |
就等于:
1
|
string javastack = "javastack" ; |
更多使用详情请参考这篇文章《java 10 实战第 1 篇:局部变量类型推断》,这里不再重复了。
2、字符串加强
java 11 增加了一系列的字符串处理方法,如以下所示。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
// 判断字符串是否为空白 " " .isblank(); // true // 去除首尾空格 " javastack " .strip(); // "javastack" // 去除尾部空格 " javastack " .striptrailing(); // " javastack" // 去除首部空格 " javastack " .stripleading(); // "javastack " // 复制字符串 "java" .repeat( 3 ); // "javajavajava" // 行数统计 "a\nb\nc" .lines().count(); // 3 |
3、集合加强
自 java 9 开始,jdk 里面为集合(list/ set/ map)都添加了 of 和 copyof 方法,它们两个都用来创建不可变的集合,来看下它们的使用和区别。
示例1:
1
2
3
|
var list = list.of( "java" , "python" , "c" ); var copy = list.copyof(list); system.out.println(list == copy); // true |
示例2:
1
2
3
|
var list = new arraylist<string>(); var copy = list.copyof(list); system.out.println(list == copy); // false |
示例1和2代码差不多,为什么一个为true,一个为false?
来看下它们的源码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
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 接口都有。
4、stream 加强
stream 是 java 8 中的新特性,java 9 开始对 stream 增加了以下 4 个新方法。
1) 增加单个参数构造方法,可为null
1
|
stream.ofnullable( null ).count(); // 0 |
2) 增加 takewhile 和 dropwhile 方法
1
2
3
|
stream.of( 1 , 2 , 3 , 2 , 1 ) .takewhile(n -> n < 3 ) .collect(collectors.tolist()); // [1, 2] |
从开始计算,当 n < 3 时就截止。
1
2
3
|
stream.of( 1 , 2 , 3 , 2 , 1 ) .dropwhile(n -> n < 3 ) .collect(collectors.tolist()); // [3, 2, 1] |
这个和上面的相反,一旦 n < 3 不成立就开始计算。
3)iterate重载
这个 iterate 方法的新重载方法,可以让你提供一个 predicate (判断条件)来指定什么时候结束迭代。
如果你对 jdk 8 中的 stream 还不熟悉,可以看之前分享的这一系列教程。
5、optional 加强
opthonal 也增加了几个非常酷的方法,现在可以很方便的将一个 optional 转换成一个 stream, 或者当一个空 optional 时给它一个替代的。
1
2
3
4
5
|
optional.of( "javastack" ).orelsethrow(); // javastack optional.of( "javastack" ).stream().count(); // 1 optional.ofnullable( null ) .or(() -> optional.of( "javastack" )) .get(); // javastack |
6、inputstream 加强
inputstream 终于有了一个非常有用的方法:transferto,可以用来将数据直接传输到 outputstream,这是在处理原始数据流时非常常见的一种用法,如下示例。
1
2
3
4
5
6
|
var classloader = classloader.getsystemclassloader(); var inputstream = classloader.getresourceasstream( "javastack.txt" ); var javastack = file.createtempfile( "javastack2" , "txt" ); try (var outputstream = new fileoutputstream(javastack)) { inputstream.transferto(outputstream); } |
7、http client api
这是 java 9 开始引入的一个处理 http 请求的的孵化 http client api,该 api 支持同步和异步,而在 java 11 中已经为正式可用状态,你可以在 java.net 包中找到这个 api。
来看一下 http client 的用法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
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!
更多使用示例可以看这个 api,后续有机会再做演示。
现在 java 自带了这个 http client api,我们以后还有必要用 apache 的 httpclient 工具包吗?
8、化繁为简,一个命令编译运行源代码
看下面的代码。
1
2
3
4
5
|
// 编译 javac javastack.java // 运行 java javastack |
在我们的认知里面,要运行一个 java 源代码必须先编译,再运行,两步执行动作。而在未来的 java 11 版本中,通过一个 java 命令就直接搞定了,如以下所示。
java javastack.java
更多新特性
•flow api for reactive programming
•java module system
•application class data sharing
•dynamic class-file constants
•java repl (jshell)
•flight recorder
•unicode 10
•g1: full parallel garbage collector
•zgc: scalable low-latency garbage collector
•epsilon: no-op garbage collector
•deprecate the nashorn javascript engine
•...
历史新特性文章
•java 11 要来了,编译运行一个命令搞定
•jdk 11 发布计划来了,已确定 3个 新特性
•java 10 实战第 1 篇:局部变量类型推断
•jdk 5 ~ 10 新特性倾情整理
•jdk 10 的 10 个新特性
•jdk 10 最重要的 5 个新特性
•jdk 9 的 9 个新特性
•jdk 9 新特性实战:简化流关闭新姿势
•jdk 8 的排序大法
•jdk 8 新特性之 lambda 表达式
•jdk 8 新特性之函数式接口
•jdk 8 新特性之方法引用
•jdk 8 新特性之接口默认方法与静态方法
•jdk 8 新特性之 optional
•jdk 8 新特性之重复注解
•jdk 8 新特性之 stream 流
•jdk 8 新特性之 stream 流(一)基础体验
•jdk 8 新特性之 stream 流(二)关键知识点
•jdk 8 新特性之 stream 流(三)缩减操作
•jdk 8 新特性之 stream 流(四)并行流
•jdk 8 新特性之 stream 流(五)映射
•jdk 8 新特性之 stream 流(六)收集缩
•jdk 8 新特性之 stream 流(七)流与迭代器
•jdk 8 新特性之扩展篇
更多新特性、新玩法,可以在 "java技术栈" 微信公众号后台回复关键字:java,获取以上所有新特性文章。
结束语
现在许多人还在使用 java 8 或者 7,不过 8 在 2019 年初就会结束免费更新。现在 11 是长期支持版本,正是学习和上手 11 的好时机,写这篇文章希望能对你有所启发。
原文链接:https://www.cnblogs.com/javastack/archive/2018/09/27/9711264.html