容器环境支持,GC等领域的增强,仅通过切换到 Java 11 就有 16% 的改进。
进行了瘦身,更轻量级,安装包体积小。
JDK11 是一个长期支持版。
Java11相对于Java8的一些新特性
1.变量类型推断
Var关键字:新版Java引入全新的类型关键字var,用var来定义的变量像python一样不用写具体类型,编译器能根据实际赋值来自动推断变量的类型
2.普通局部变量
3.For循环中使用
4.Var结合泛型
注意:var不能在类成员变量类型和方法返回值类型使用
5.增强api
6.String 增强
7.集合增强
增加了一些更加方便的创建和复制集合类型的API
● of() @since 9
● copyOf() @since 10
8.Stream增强
Java 8 中的流已经很强大了,而且只要涉及到 IO,只要涉及到对一系列数据进行操作,都会用到流。
当然了,Java 9对其操作继续增强,这次的改进主要是如何设置停止流的条件上。为此在流的实例上提供了四个方法 takeWhile(Predicate Interface) 、iterate 、ofNullable 和 dropWhile(Predicate Interface)
HTTP Client API
新版jdk官方自带httpClient,支持发送同步、异步的http请求
完全支持Linux容器(包括docker)
许多运行在Java虚拟机中的应用程序(包括Apache Spark和Kafka等数据服务以及传统的企业应用程序)都可以在Docker容器中运行。但是在Docker容器中运行Java应用程序一直存在一个问题,那就是在容器中运行JVM程序在设置内存大小和CPU使用率后,会导致应用程序的性能下降。这是因为Java应用程序没有意识到它正在容器中运行。随着Java 10的发布,这个问题总算得以解决,JVM现在可以识别由容器控制组(cgroups)设置的约束。可以在容器中使用内存和CPU约束来直接管理Java应用程序,其中包括:
● 遵守容器中设置的内存限制
● 在容器中设置可用的CPU
● 在容器中设置CPU约束
升级过程中遇到的一些问题
1. javax.xml.bind 不存在
Java11 删除了 Java EE modules,其中就包括 java.xml.bind (JAXB)。
启动时警告:
解决方案:手动添加相关依赖
<dependency>
<groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId>
<version>2.3.0</version>
</dependency>
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-core</artifactId>
<version>2.3.0</version>
</dependency>
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-impl</artifactId>
<version>2.3.0</version>
</dependency>
由于JDK11中删除了sum.misc包,编译时会报错:sun.misc.BASE64Encoder、sun.misc.BASE64Decoder找不到类
使用java.util.Base64.Encoderjava.util.Base64.Decoder替换
3.服务启动报错
① JDK11下使用最新的Greenwich版本的eureka默认情况下必定无法启动,日志提示内嵌的Tomcat没法启动
解决方式:加入JAXB依赖
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>jaxb-runtime</artifactId>
<version>2.3.2</version>
</dependency>
解决方式:加入JAXB依赖
<dependency>
<groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId>
</dependency>
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-impl</artifactId>
<version>2.3.0</version>
</dependency>
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>jaxb-runtime</artifactId>
<version>2.3.0</version>
</dependency>
<dependency>
<groupId>javax.activation</groupId>
<artifactId>activation</artifactId>
<version>1.1.1</version>
</dependency>
趋势
从Java 11开始,OpenJDK major version的发布间隔差不多是半年,不用全部都要去关注,都是追赶,但是LTS版本,需要去追赶,去升级,Java11就是最新的LTS版本,下一个或者再一下major version,很可能又是一个LTS版本;虽然目前使用Java 8都挺好的,现实是Java 8的一些特性会被往后移植,但是后续版本的特性和优化不会再被集成到Java 8中了。