美国时间 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