百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

java进化史2 java序列化

yuyutoo 2024-10-23 16:40 21 浏览 0 评论

java 进化史1

目前来看,使用量最多的三个版本应该是JDK8,JDK11,JDK17 了。这三个版本也是LTS版本,同时推荐大家使用的版本。

因为JDK8以后,oracle宣布商用版本开始收费,所以很多人一直没有升级,大家都觉得我的8还能再战十年,不过也差不多哈,[笑哭]哈哈哈。。。

jdk8将更新到 至少2030年12月。

jdk11 将更新到至少 2026年9月。

jdk17 将更新到至少 2024年9月。

jdk18 将更新到2022年9月,到时将会被jdk19取代。

还是8牛逼哈,不想更新的兄弟们可以接着白嫖

Java SE 8 LTS

2014年3月发布,主要特性:

  • JSR 335,JEP 126:Lambda项目中提供的语言级匿名函数支持(官方称为Lambda表达式,非官方亦称为闭包
  • JSR 223,JEP 174:Nashorn项目,一个JavaScript运行时,允许开发人员在应用程序中嵌入JavaScript代码
  • JSR 308,JEP 104:在Java类型上的注解
  • JSR 337,JEP 120:重复注解Repeatable
  • JSR 310,JEP 150:日期和时间API,基于Joda-Time日期时间处理库的实现
  • JEP 178:静态连接JNI程序库
  • JEP 153:执行JavaFX应用程序(直接执行JavaFX的应用程序的JAR包)
  • JEP 122:移除了虚拟机内存管理中的永久世代,使用元空间Metaspace代替
  • 无符号整数算术
  • 函数式接口
  • 方法引用
  • 接口默认方法
  • Stream API
  • Optional解决NullPointerException
  • Base64

Java SE 9

2017年9月发布,非LTS版本,OpenJDK于2018年3月停止更新,主要特性:

  • JSR 376:在Jigsaw项目中将JDK模块化
  • JEP 222:JShell
  • JEP 295:AOT编译(通过Graal VM实现)
  • JEP 268:XML Catalogs
  • JEP 266:更多的并发更新,包含响应式流的Java实现,及其部分替代品java.util.concurrent.Flow
  • JEP 193:变量句柄,定义一个标准方法来调用java.util.concurrent.atomic和sun.misc.Unsafe操作的等价物
  • JEP 282:jlink,Java链接器,该工具可以为模块生成一个包含了其所有依赖项的自定义运行时映像,同时允许生成一个包括运行它的JVM的可执行文件
  • JavaDB被移出JDK
  • JEP 263:高DPI图像,自动缩放与尺寸自适应
  • 提供List.of()、Set.of()、Map.of()和Map.ofEntries()等工厂方法
  • 接口支持私有方法
  • Optional类改进
  • 多版本兼容JAR包
  • try-with-resources改进
  • Stream API改进

Java SE 10

2018年3月发布,非LTS版本,OpenJDK于2018年9月停止更新,主要特性:

  • JEP 286:局部变量类型推断
  • JEP 317:实验性的基于Java的JIT编译器,Linux x64下Graal动态编译器的集成
  • JEP 310:应用程序类级别数据共享
  • JEP 322:基于时间的版本命名
  • JEP 307:适用于G1的多线程完全垃圾回收
  • JEP 304:垃圾回收器接口
  • JEP 314:更多的Unicode语言标签扩展
  • JEP 319:内置根证书
  • JEP 312:线程本地握手
  • JEP 316:在可选的内存设备上申请堆内存空间
  • JEP 313:删除本地代码头文件生成器javah
  • JEP 296:将所有JDK分支集成到同一个版本库中
  • 不可变集合改进
  • Optional新增orElseThrow()方法

Java SE 11

2018年9月发布,LTS版本,AdoptOpenJDK于2024年10月或之后停止更新,Amazon Corretto于2027年9月或之后停止更新,最后延伸支持日期:2026年9月
主要特性:

  • JEP 181:针对嵌套成员的访问控制
  • JEP 309:动态类文件常量
  • JEP 315:利用Aarch64的特有架构改进其上的性能
  • JEP 318:Epsilon,无操作垃圾收集器
  • JEP 320:移除Java EE和CORBA模块
  • JEP 321:HTTP Client重写,支持HTTP/1.1和HTTP/2,也支持websockets
  • JEP 323:Lambda参数的局部变量语法
  • JEP 324:支持Curve25519和Curve 448密钥
  • JEP 327:Unicode 10
  • JEP 328:添加Java飞行记录器(JFR),其用于创建性能分析记录
  • JEP 329:ChaCha20和Poly1305加密算法
  • JEP 330:运行单文件源码程序
  • JEP 331:低开销堆分析
  • JEP 332:支持TLS 1.3
  • JEP 333:添加ZGC(一个可扩展的低延迟垃圾收集器)
  • JEP 335:弃用Nashorn JavaScript引擎
  • JEP 336:弃用Pack200相关的工具及API
  • 增加一些字符串处理方法

Java SE 12

2019年3月发布,非LTS版本,OpenJDK于2019年9月停止更新,主要特性:

  • JEP 189:Shenandoah,一个实验性的低延迟垃圾收集器
  • JEP 230:细粒度性能评审包
  • JEP 325:Switch表达式扩展(预览阶段)
  • JEP 334:JVM Constants API
  • JEP 340:仅保留一个AArch64平台的移植
  • JEP 341:默认类数据共享归档
  • JEP 344:针对G1,提供可中止的混合垃圾收集
  • JEP 346:针对G1,及时释放已申请但未使用的内存
  • 新增NumberFormat对复杂数字的格式化
  • 字符串支持transform、indent操作
  • 新增方法Files.mismatch(Path, Path)
  • Teeing Collector
  • 支持Unicode 11

Java SE 13

2019年9月发布,非LTS版本,OpenJDK于2020年3月停止更新,主要特性:

  • JEP-350:动态CDS归档
  • JEP-351:增强ZGC释放未使用内存
  • JEP-353:重新实现旧版Socket API
  • JEP-354:Switch表达式扩展,引入yield关键字(预览版本)
  • JEP-355:文本框(预览阶段)
  • 增强ZGC释放未使用内存

Java SE 14

2020年3月发布,非LTS版本,OpenJDK于2020年9月停止更新,主要特性:

  • JEP-305:使用instanceof的模式匹配(预览)
  • JEP-343:打包工具(孵化中)
  • JEP-345:在G1中,对不均匀的内存访问(NUMA)情况下的内存申请优化
  • JEP-349:JFR Event Streaming
  • JEP-352:使字节缓冲区能够映射到非易失性存储器上
  • JEP-358:有帮助的NullPointerExceptions
  • JEP-359:记录类(预览)
  • JEP-361:Switch表达式(标准)
  • JEP-362:弃用Solaris和SPARC平台上的移植版本
  • JEP-363:移除Concurrent Mark Sweep(CMS)垃圾收集器
  • JEP-364:适用于MacOS的ZGC
  • JEP-365:适用于Windows的ZGC
  • JEP-366:弃用ParallelScavenge+SerialOld的垃圾收集器组合
  • JEP-367:移除Pack200相关的工具及API
  • JEP-368:文本块(第二预览版本)
  • JEP-370:外部内存访问API(孵化中)
  • Record类型,类似于Lombok的@Data注解

Java SE 15

2020年9月发布,非LTS版本,OpenJDK于2021年3月停止更新,主要特性:

  • JEP 339:Edwards-Curve数据签名算法(EdDSA),EdDSA是一种现代的椭圆曲线签名方案
  • JEP 360:封闭类(预览)Sealed Classes,可以是封闭类或封闭接口,防止其他类或接口扩展或实现
  • JEP 371:隐藏类Hidden Classes,不能直接被其他类的字节码使用,只能在运行时生成类并通过反射间接使用它们
  • JEP 372:移除Nashorn JavaScript脚本引擎、APIs及jjs工具
  • JEP 373:重新实现DatagramSocket API接口,更改java.net.DatagramSocket和java.net.MulticastSocket为更简单的底层实现,更易于维护和调试,新的底层实现将很容易使用虚拟线程
  • JEP 374:准备禁用和废除偏向锁
  • JEP 375:使用instanceof的模式匹配(第二次预览)
  • JEP 377:ZGC,一个可伸缩、低延迟的垃圾回收器
  • JEP 378:文本块"""
  • JEP 379:Shenandoah,一个低停顿时间的垃圾回收器
  • JEP 381:移除Solaris和SPARC端口,移除了Solaris/SPARC、Solaris/x64和Linux/SPARC端口的源代码及构建支持
  • JEP 383:外存访问API(孵化),可以允许Java应用程序安全有效地访问Java堆之外的外部内存
  • JEP 384:Records(第二次预览),某些场合可以干掉Lombok,能自动生成类构造器、toString()、hashCode()、equals()以及类似getter的变量访问方法
  • JEP 385:废除RMI激活,RMI激活是RMI种一个过时的组件

Java SE 16

2021年3月发布,非LTS版本,OpenJDK与2021年9月停止更新,主要特性:

  • JEP 338:提供了jdk.incubator.vector来用于矢量计算
  • JEP 347:在JDK C++的源码中允许使用C++14的语言特性
  • JEP 357:OpenJDK源码的版本控制从Mercurial(hg)迁移到git
  • JEP 369:将OpenJDK源码的版本控制迁移到GitHub上
  • JEP 376:ZGC,实现了并发thread-stack处理来降低GC safepoints的负担
  • JEP 380:对socket channel及server socket channel的api提供对unix domain socket的支持
  • JEP 386:将glibc的jdk移植到使用musl的alpine linux上
  • JEP 387:支持不再使用的class metadata归还内存给操作系统,降低内存占用
  • JEP 388:移植JDK到Windows/AArch64
  • JEP 389:提供jdk.incubator.foreign来简化native code的调用
  • JEP 390:提供@jdk.internal.ValueBased来用于标注作为value-based的类
  • JEP 392:jpackage在JDK14引入,JDK15作为incubating工具,在JDK16转正,从jdk.incubator.jpackage转为jdk.jpackage,它支持Linux:deb & rpm,MacOS:pkg & dmg,Windows:msi & exe

Java SE 17

2021年9月发布,LTS版本,Azul于2029年9月停止更新,Microsoft于2027年9月停止更新,最后延伸支持日期:2024年9月
主要特性:

  • JEP 306:恢复始终执行严格模式的浮点定义,修复25年前英特尔的浮点指令存在的一些问题
  • JEP 356:引入RandomGenerator及RandomGeneratorFactory提供更好的随机数生成
  • JEP 382:使用Apple Metal API为MacOS新增了Java 2D internal rendering pipeline
  • JEP 391:迁移JDK到MacOS/AArch64
  • JEP 398:标记Applet API为废弃方便后续移除
  • JEP 403:对JDK内部的API进行更强的封装
  • JEP 406:引入switch模式匹配的preview版本,instanceof的模式匹配在JDK14作为preview,在JDK15作为第二轮的preview,在JDK16转正
  • JEP 407:移除Remote Method Invocation(RMI),它在JDK15的JEP 385被废弃
  • JEP 409:Sealed Classes在JDK15作为preview引入,在JDK16作为第二轮preview,在JDK17转正
  • JEP 410:移除实验性的Java版本的AOT及JIT Compiler
  • JEP 411:废弃Java1.0引入的Security Manager方便后续移除
  • JEP 412:引入Foreign Function & Memory API
  • JEP 414:JDK 16引入了Vector API(Incubator)提供了jdk.incubator.vector来用于矢量计算,JDK17进行改进并作为第二轮incubator
  • JEP 415:允许应用去配置指定上下文及动态选择的deserialization filters

Java SE 18

2022年3月发布,JDK 18 将是一个短期功能版本,只支持六个月。
主要特性:

  • JEP 400:指定 UTF-8 作为标准 Java API 的默认字符集。
  • JEP 408:引入一个简单的 Web 服务器。
  • JEP 413:支持在 Java API 文档中加入代码片段。
  • JEP 416 :用方法句柄重新实现核心反射。
  • JEP 417:Vector API(第三孵化器)。
  • JEP 418:互联网地址解析 SPI。
  • JEP 419:外部函数和内存 API(第二孵化器)。
  • JEP 420: switch 模式匹配表达式。
  • JEP 421:弃用 Finalization 功能。

参考文章:
https://www.jianshu.com/p/f3c16441b746

相关推荐

ETCD 故障恢复(etc常见故障)

概述Kubernetes集群外部ETCD节点故障,导致kube-apiserver无法启动。...

在Ubuntu 16.04 LTS服务器上安装FreeRADIUS和Daloradius的方法

FreeRADIUS为AAARadiusLinux下开源解决方案,DaloRadius为图形化web管理工具。...

如何排查服务器被黑客入侵的迹象(黑客 抓取服务器数据)

---排查服务器是否被黑客入侵需要系统性地检查多个关键点,以下是一份详细的排查指南,包含具体命令、工具和应对策略:---###**一、快速初步检查**####1.**检查异常登录记录**...

使用 Fail Ban 日志分析 SSH 攻击行为

通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...

《5 个实用技巧,提升你的服务器安全性,避免被黑客盯上!》

服务器的安全性至关重要,特别是在如今网络攻击频繁的情况下。如果你的服务器存在漏洞,黑客可能会利用这些漏洞进行攻击,甚至窃取数据。今天我们就来聊聊5个实用技巧,帮助你提升服务器的安全性,让你的系统更...

聊聊Spring AI Alibaba的YuQueDocumentReader

序本文主要研究一下SpringAIAlibaba的YuQueDocumentReaderYuQueDocumentReader...

Mac Docker环境,利用Canal实现MySQL同步ES

Canal的使用使用docker环境安装mysql、canal、elasticsearch,基于binlog利用canal实现mysql的数据同步到elasticsearch中,并在springboo...

RustDesk:开源远程控制工具的技术架构与全场景部署实战

一、开源远程控制领域的革新者1.1行业痛点与解决方案...

长安汽车一代CS75Plus2020款安装高德地图7.5

不用破解原车机,一代CS75Plus2020款,安装车机版高德地图7.5,有红绿灯读秒!废话不多讲,安装步骤如下:一、在拨号状态输入:在电话拨号界面,输入:*#518200#*(进入安卓设置界面,...

Zookeeper使用详解之常见操作篇(zookeeper ui)

一、Zookeeper的数据结构对于ZooKeeper而言,其存储结构类似于文件系统,也是一个树形目录服务,并通过Key-Value键值对的形式进行数据存储。其中,Key由斜线间隔的路径元素构成。对...

zk源码—4.会话的实现原理一(会话层的基本功能是什么)

大纲1.创建会话...

Zookeeper 可观测性最佳实践(zookeeper能够确保)

Zookeeper介绍ZooKeeper是一个开源的分布式协调服务,用于管理和协调分布式系统中的节点。它提供了一种高效、可靠的方式来解决分布式系统中的常见问题,如数据同步、配置管理、命名服务和集群...

服务器密码错误被锁定怎么解决(服务器密码错几次锁)

#服务器密码错误被锁定解决方案当服务器因多次密码错误导致账户被锁定时,可以按照以下步骤进行排查和解决:##一、确认锁定状态###1.检查账户锁定状态(Linux)```bash#查看账户锁定...

zk基础—4.zk实现分布式功能(分布式zk的使用)

大纲1.zk实现数据发布订阅...

《死神魂魄觉醒》卡死问题终极解决方案:从原理到实战的深度解析

在《死神魂魄觉醒》的斩魄刀交锋中,游戏卡死犹如突现的虚圈屏障,阻断玩家与尸魂界的连接。本文将从技术架构、解决方案、预防策略三个维度,深度剖析卡死问题的成因与应对之策,助力玩家突破次元壁障,畅享灵魂共鸣...

取消回复欢迎 发表评论: