8年java_Java 11 正式发布!8年免费使用!

根据Oracle新出台的每6个月发布一次Java SE的节奏,美国时间9月25日,Oracle 官方宣布 Java 11 (18.9 LTS) 正式发布,可供生产环境中使用,这是自Java8后的首个长期支持版本,深得大家关注。

其下载地址如下:

https://www.oracle.com/technetwork/java/javase/downloads/jdk11-downloads-5066655.html

Java 11 版本说明

按照 Oracle 公布的支持路线图,Java 11 将会获得 Oracle 提供的长期支持服务,直至2026年9月。

新的长期支持版本每三年发布一次,根据后续的发布计划,下一个长期支持版 Java 17 将于2021年发布。

Oracle 公布的未来 Java 版本发布和支持周期图

Java 11 亮点关注

虽然6个月前才发布了Java10,但这也并不意味着Java11的亮点不足以吸引大家眼球。

官网公开的 Java11 共有以下 17 项更新:

181:Nest-Based Access Control(基于嵌套的访问控制)

309:Dynamic Class-File Constants

(动态类文件常量)

315: Improve Aarch64 Intrinsics

(改进 Aarch64 内部函数)

318:Epsilon: A No-Op Garbage Collector(Epsilon:No-Op 垃圾收集器)

320:Remove the Java EE and CORBA Modules(删除 Java EE 和 CORBA 模块)

321:HTTP Client (Standard)(HTTP 客户端)

323:Local-Variable Syntax for Lambda Parameters(Lambda 参数的变量语法)

324:Key Agreement with Curve25519 and Curve448(采用 Curve25519 和 Curve448 算法实现的密钥协议)

327:Unicode 10

328:Flight Recorder(飞行记录器)

329:ChaCha20 and Poly1305 Cryptographic Algorithms(ChaCha20 和 Poly1305 加密算法)

330:Launch Single-File Source-Code Programs(启动单文件源代码程序)

331:Low-Overhead Heap Profiling(低开销堆分配采样方法)

332: Transport Layer Security (TLS) 1.3(TLS 1.3 的传输层安全性)

333:ZGC: A Scalable Low-Latency Garbage Collector(Experimental)(ZGC:可扩展的低延迟垃圾收集器,在实验阶段)

335:Deprecate the Nashorn JavaScript Engine(弃用 Rhino JavaScript 引擎)

336:Deprecate the Pack200 Tools and API(弃用 Pack200 工具和 API)

简单介绍几个比较重要的新特性:

ZGC:可扩展的低延迟垃圾收集器

ZGC是一款号称可以保证每次GC的停顿时间不超过10MS的垃圾回收器,并且和当前的默认垃圾回收起G1相比,吞吐量下降不超过15%。

Epsilon:什么事也不做的垃圾回收器

Java 11还加入了一个比较特殊的垃圾回收器——Epsilon,该垃圾收集器被称为“no-op”收集器,将处理内存分配而不实施任何实际的内存回收机制。 也就是说,这是一款不做垃圾回收的垃圾回收器。这个垃圾回收器看起来并没什么用,主要可以用来进行性能测试、内存压力测试等,Epsilon GC可以作为度量其他垃圾回收器性能的对照组。

增强var用法

Java 10中增加了本地变量类型推断的特性,可以使用var来定义局部变量。

从 Java 10 开始,可以使用关键字 var 声明局部变量,如下所示:

尽管这一特性被很多人诟病,但是并不影响Java继续增强他的用法,在Java 11中,var可以用来作为Lambda表达式的局部变量声明。乍一看,这一举措似乎有点多余,因为在写代码过程中可以省略 lambda 参数的类型,并通过类型推断确定它们。但是,扩展名对于使用 @Nonnull 和 @Nullable 等类型注释很有用。

移除Java EE和CORBA模块

早在发布Java SE 9的时候,Java就表示过,会在未来版本中将Java EE和CORBA模块移除,而这样举动终于在Java 11中实施。终于去除了Java EE和CORBA模块。

HTTP客户端进一步升级

JDK 9 中就已对 HTTP Client API 进行标准化,然后通过JEP 110,在 JDK 10 中进行了更新。在本次的Java 11的更新列表中,由以JEP 321进行进一步升级。

该API通过CompleteableFutures提供非阻塞请求和响应语义,可以联合使用以触发相应的动作。 JDK 11完全重写了该功能。现在,在用户层请求发布者和响应发布者与底层套接字之间追踪数据流更容易了,这降低了复杂性,并最大程度上提高了HTTP / 1和HTTP / 2之间的重用的可能性。

启动单文件源代码程序

如今单文件程序在编写小实用程序时很常见,特别是脚本语言领域。从中开发者可以省去用 Java 编译程序等不必要工作,以及减少新手的入门障碍。在基于 Java 10 的程序中可以通过三种方式启动:

作为* .class文件

作为* .jar文件中的主类

作为模块中的主类

现在,Java 11 中可以在源代码文件中声明类:

在 Unix 操作系统上,Java 文件甚至可以直接作为 Shebang 文件执行:

其他值得注意的变化包括支持 Unicode 10 标准以及将 Profiler Flight Recorder 集成到 OpenJDK 中(之前仅适用于 Oracle JDK)。Flight Recorder 的目标是尽可能高效地记录应用程序数据,以便在出现问题时分析 Java 应用程序和 JVM。

API的变化

此外,Java 类库也有不少小的改动。 特别是字符串:

Java 11 是否值得更新

今年4月,Oracle 发布官方声明表示即将停止对 Java 8 的正常支持(免费更新):

2019 年 1 月之后,Oracle 将不会在其网站上发布 Java SE 8 商业使用的进一步更新下载。如需持续获取安全的 Bug 修复和安全补丁以及 Java SE 8 或以前版本的稳定性支持,可以通过 Oracle Java SE 高级版、Oracle Java SE 高级桌面、或 Oracle Java SE 套件。

这意味着,在 2019 年 1 月之后,开发者想要使用老版本只能付费了,从中也侧面看出,Oracle 在间接性鼓励用户主动升级。不过,据各种对 Java 用户调查如 Jaxenter 发现,大多数的开发者依旧停留在 Java 8 以内的版本。

其实,这也不足为怪,当开发者刚开始吐槽新版本带来的问题时,Java 已搭载上了火箭更新到了下一版本,让大家措手不及。

那么对于 Java 11 是否值得立即更新使用?按照 Oracle 公布支持的路线图来看,如文章开头所述,Java 11 将会获得 Oracle 长期的服务支持,直至 2026 年 9 月。相比 Java 9 和 10 这两个仅提供半年技术支持的版本来说,Java11 的发布无疑对个人开发者以及企业都是一件好事。

-END-

去企业,学习企业需要的编程技能!

中软卓越,真实企业背景,

送你企业入场券!

唯有企业,更懂企业

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值