杂谈

很多主流项目都放弃了Java 8,背后的原因是什么

大家有没有发现,现在越来越多的软件安装时最低要求都是 Java 11。比如 Flink。

FlinkFlink

SonarQube最新版甚至最低要求 Java 17。

SonarQubeSonarQube

那么真正放弃 Java 8 的原因是什么呢?

1. Java 新特性(如Java 11)

1.1局部变量类型推断(Local Variable Type Inference)

引入了 var 关键字,使得在局部变量声明时可以使用类型推断。例如,var name = "John"; 将会被推断为 String 类型。

1.2 针对字符串的新增方法

Java 11 引入了一些针对字符串处理的新方法,如 isBlank()、lines() 和 stripIndent() 等,用于更方便地操作字符串。

1.3 HTTP/2 客户端 API

在 Java 11 中,提供了一个原生的 HTTP/2 客户端 API,用于进行 HTTP 请求和响应的处理,以替代传统的 HttpURLConnection。

1.4 响应式流(Reactive Streams)API

Java 9 引入的 Flow API 在 Java 11 进一步发展,并成为标准化的响应式流 API。它支持异步流式处理和背压机制。

1.5 ZGC 改进

ZGC 是一种低暂停时间的垃圾回收器,在 Java 11 中进行了一些改进,进一步降低了垃圾回收的停顿时间,并提高了应用程序的吞吐量。

1.6 Epsilon 垃圾回收器

Epsilon 是一种无操作的垃圾回收器,用于测试和性能调优。它允许你在没有任何垃圾回收的情况下运行 Java 应用程序,适用于一些特定的场景。

1.7 集合 API 改进

Java 11 对集合 API 进行了一些改进,包括新的方法和接口,如 List.of()、Set.of() 和 Map.of() 等用于创建不可变集合的静态工厂方法。

1.8 新的垃圾回收器接口

Java 11 引入了一组垃圾回收器接口,允许开发者可以更方便地实现自定义的垃圾回收器和内存分配器。

2. 长期支持(LTS)版本

Java 8 和 11 都是长期支持版本,支持的时间 Java 11 更长(官网数据)。

3.生态系统支持

随着时间的推移,越来越多的开源库和框架开始逐步升级到 Java 11,并且停止或降低对 Java 8 的支持。选择最低支持 Java 11 可以确保你能够使用最新的第三方库和框架,充分利用其功能和优化。

4.安全性和性能优化

Java 11 引入了一些安全性和性能方面的改进,包括 TLS 1.3 支持、改进的 HTTP 处理、本地内存访问 API 等。使用较新的 Java 版本可以提供更好的安全性和性能。

本页面仅提供《很多主流项目都放弃了Java 8,背后的原因是什么》的在线阅读查看,您观看的《很多主流项目都放弃了Java 8,背后的原因是什么》内容为网络转载,如果您觉得《很多主流项目都放弃了Java 8,背后的原因是什么》侵犯了您的权益以及对您造成影响,请联系我们进行删除。