首页 > 编程语言 >Java 23连夜官宣发布,IDEA亲测可用!

Java 23连夜官宣发布,IDEA亲测可用!

时间:2024-09-18 15:03:28浏览次数:1  
标签:JEP java JDK 23 官宣 IDEA API 模块 Java

0 前言

官宣发布:

IDEA已支持下载:

1 JEPs

JEP 455 Primitive Types in Patterns, instanceof, and switch (Preview)

通过允许在所有模式上下文中使用原始类型模式,增强了模式匹配,并扩展了 instanceofswitch 以适用于所有原始类型。这是一项预览语言特性

JEP 466 Class-File API (Second Preview)

提供解析、生成和转换 Java 类文件的标准 API。这是一项预览 API

JEP 467 Markdown文档注释

使 JavaDoc 文档注释能够用 Markdown 而非 HTML 和 JavaDoc @ 标签的混合体编写。

JEP 469 Vector API (Eighth Incubator)

引入一个 API 来表达向量计算,这些计算在运行时可靠地编译为支持的 CPU 架构上的最佳向量指令,从而实现优于等效标量计算的性能。

JEP 471 废除 Memory-Access Methods in sun.misc.Unsafe for Removal

sun.misc.Unsafe 中的内存访问方法标记为将来版本中删除。这些不受支持的方法已被标准 API 取代,即 VarHandle API (JEP 193, JDK 9) 和 Foreign Function & Memory API (JEP 454, JDK 22)。强烈鼓励库开发者从 sun.misc.Unsafe 迁移到支持的替代品,以便应用程序能够顺利迁移到现代 JDK 版本。

JEP 473 Stream Gatherers (Second Preview)

增强 Stream API 以支持自定义中间操作。这将允许流管道以不容易用现有内置中间操作实现的方式转换数据。这是一项预览 API

JEP 474 ZGC: Generational Mode by Default

将ZGC默认模式切换为分代模式。弃用非分代模式,并计划在未来版本中删除。

JEP 476 Module Import Declarations (Preview)

简洁地导入模块导出的所有包。简化了模块库重用,但不需要导入代码本身处于模块中。预览语言特性

JEP 477 Implicitly Declared Classes and Instance Main Methods (Third Preview)

发展 Java 编程语言,以便初学者在不需要理解为大型程序设计的语言特性的情况下编写首个程序。远非使用语言的单独方言,初学者可为单类程序编写简化的声明,然后随技能提升,无缝扩展程序以使用更高级特性。经验丰富开发同样可享受简洁编写小程序乐趣,而无需使用旨在大规模编程的构造。预览语言特性

JEP 480 Structured Concurrency (Third Preview)

通过引入 结构化并发 API简化并发编程。结构化并发将不同线程中运行的一组相关任务视为单一工作单元,简化错误处理和取消操作,提高可靠性,并增强可观察性。预览 API

JEP 481 Scoped Values (Third Preview)

引入 作用域值,使方法能在线程内与其被调用者共享不可变数据,并与子线程共享。作用域值比线程局部变量更易理解。还具有更低空间和时间成本,尤其与虚拟线程 (JEP 444) 和结构化并发 (JEP 480) 一起使用时。预览 API

JEP 482 Flexible Constructor Bodies (Second Preview)

允许在显式构造函数调用(即 super(..)this(..))之前出现语句。这些语句不能引用正在构造的实例,但它们可初始化其字段。在调用另一个构造函数之前初始化字段,当方法被覆盖时,可以使类更可靠。预览语言特性

2 新特性

带明确区域设置的控制台方法 (JDK-8330276)

core-libs/java.io

java.io.Console 类添加了以下方法,这些方法接受一个 java.util.Locale 参数:

  • public Console format(Locale locale, String format, Object ... args)
  • public Console printf(Locale locale, String format, Object ... args)
  • public String readLine(Locale locale, String format, Object ... args)
  • public char[] readPassword(Locale locale, String format, Object ... args)

用户现在可以用指定的 Locale 格式化输出字符串或显示提示文本,该 Locale 可能与默认区域设置无关。例如,代码片段 System.console().printf(Locale.FRANCE, "%1$tY-%1$tB-%1$te %1$tA", new Date()) 将显示:

2024-五月-16 星期四

支持直到另一个瞬间的持续时间 (JDK-8331202)

core-libs/java.time

java.time.Instant 类添加了一个新的方法,以获得直到指定 InstantDuration。新方法 Instant.until(Instant) 产生的持续时间与 Duration.between(Temporal, Temporal) 相同,但更易于用户发现。此外,与 Instant.until(Temporal, TemporalUnit) 方法相比,新方法直接返回一个 Duration,无需单位转换。

新的 Parallel GC Full GC 算法 (JDK-8329203)

hotspot/gc

Parallel GC 现在使用与 Serial GC 和 G1 GC Full GCs 中相同的 Full GC 算法。

以前的算法包括通过 Java 堆中的每个活动对象进行三次传递:

  1. 标记活动对象
  2. 计算每个活动对象的新位置
  3. 移动对象到新位置并更新每个对象的字段

在第 2 步中计算的对象位置使用非堆内存存储,以避免通过 Java 堆中的活动对象进行第四次传递。问题是这种方案对于某些问题工作负载来说扩展性不好。此外,这种数据结构使用 Java 堆的 1.5% 作为非堆内存。

新算法对于问题工作负载的性能显著更好,并且不需要额外的内存,减少了所有工作负载的占用空间。

3 已移除的特性和选项

移除 ThreadGroup.stop (JDK-8320786)

core-libs/java.lang

在此版本中已移除 java.lang.ThreadGroup.stop() 方法。这个固有不安全的方法在 JDK 1.2 (1998) 中已被弃用,在 Java 18 中弃用于删除,并在 Java 20 中重新规定/降级为无条件抛出 UnsupportedOperationException。使用此方法的代码将不再编译。在旧版本上编译的代码,如果在使用 JDK 23 或更新版本时执行,现在会抛出 NoSuchMethodError 而不是 UnsupportedOperationException

移除 Thread.suspend/resumeThreadGroup.suspend/resume (JDK-8320532)

core-libs/java.lang

在此版本中已移除 java.lang.Thread.suspend()java.lang.Thread.resume()java.lang.ThreadGroup.suspend()java.lang.ThreadGroup.resume() 方法。这些容易死锁的方法在 JDK 1.2 (1998) 中已被弃用,在 Java 14 中弃用于删除,并在 Java 19/20 中重新规定/降级为无条件抛出 UnsupportedOperationException。使用这些方法的代码将不再编译。在旧版本上编译的代码,如果在使用 JDK 23 或更新版本时执行,现在会抛出 NoSuchMethodError 而不是 UnsupportedOperationException

移除模块 jdk.random (JDK-8330005)

core-libs/java.util

已从 JDK 中移除 jdk.random 模块。该模块包含 java.util.random.RandomGenerator 算法的实现。这些实现已移动到 java.base 模块,java.base 模块现在将负责支持这些算法。

依赖 jdk.random 模块的应用程序,无论是通过构建脚本还是通过模块依赖项,都应删除对此模块的引用。

关注我,紧跟本系列专栏文章,咱们下篇再续!

作者简介:魔都架构师,多家大厂后端一线研发经验,在分布式系统设计、数据平台架构和AI应用开发等领域都有丰富实践经验。

各大技术社区头部专家博主。具有丰富的引领团队经验,深厚业务架构和解决方案的积累。

负责:

  • 中央/分销预订系统性能优化
  • 活动&券等营销中台建设
  • 交易平台及数据中台等架构和开发设计
  • 车联网核心平台-物联网连接平台、大数据平台架构设计及优化
  • LLM Agent应用开发
  • 区块链应用开发
  • 大数据开发挖掘经验
  • 推荐系统项目

目前主攻市级软件项目设计、构建服务全社会的应用系统。

参考:

本文由博客一文多发平台 OpenWrite 发布!

标签:JEP,java,JDK,23,官宣,IDEA,API,模块,Java
From: https://www.cnblogs.com/JavaEdge/p/18418527

相关文章

  • 算法学习每日一题之2332. 坐上公交的最晚时间:二分答案 & 贪心双指针
    Problem:2332.坐上公交的最晚时间人话题意:你是一个懒惰的人,虽然你要赶公交车,但你想多睡会,恰好你知道每辆车的发车时间buses和每辆车容capacity,和每个乘客乘车的时间passenger,旨在求可以赶上公交车的最晚出发时间。思路一:二分答案求最晚能满足赶上公交的时间,可以发现......
  • 2320. 统计放置房子的方式数
    题目链接2320.统计放置房子的方式数思路动态规划-斐波拉契数列题解链接线性DP(Python/Java/C++/Go)关键点无时间复杂度\(O(n)\)空间复杂度\(O(n)\)代码实现:MOD=10**9+7f=[1,2]for_inrange(10**4-1):f.append((f[-1]+f[-2......
  • 【每日一题】LeetCode 2332.坐上公交的最晚时间(数组、双指针、二分查找、排序)
    【每日一题】LeetCode2332.坐上公交的最晚时间(数组、双指针、二分查找、排序)题目描述给你一个下标从0开始长度为n的整数数组buses,其中buses[i]表示第i辆公交车的出发时间。同时给你一个下标从0开始长度为m的整数数组passengers,其中passengers[j]表示第......
  • 23为期塞4缺乏的萨克拉人头减肥啊溶剂法
    https://files.cnblogs.com/files/blogs/816103/wesbos.theme-cobalt2-2.4.3.zip?t=1726630691&download=truehttps://files.cnblogs.com/files/blogs/816103/tomoki1207.pdf-1.2.2.zip?t=1726630687&download=truehttps://files.cnblogs.com/files/blogs/816103/Di......
  • springboot家校共育平台-计算机毕业设计源码54235
    摘 要采用高效的SpringBoot框架,家校共育平台为家长与教师提供了便捷的沟通渠道。该平台整合了丰富的教育资源,实现了家校之间的即时信息互通,从而助力协同教育。为进一步方便用户访问和使用,平台与微信小程序进行了深度整合。家长和教师现在可以通过微信小程序轻松访问平台,无......
  • 替西帕肽;Mounjaro;Tirzepatide;CAS:2023788-19-2
    【替西帕肽Tirzepatide简介】    替西帕肽是一种GIP/GLP-1受体激动剂,由39个氨基酸的多肽组成。Tirzepatide(LY3298176)是葡萄糖依赖性胰岛素营养多肽(GIP)和胰高血糖素样肽-1(GLP-1)受体双重激动剂。Tirzepatide(LY3298176)在血糖控制和体重减轻方面的疗效明......
  • 文心一言 VS 讯飞星火 VS chatgpt (349)-- 算法导论23.2 8题
    八、Borden教授提出了一个新的分治算法来计算最小生成树。该算法的原理如下:给定图,将划分为两个集合和,使得和的差最多为1。设为端点全部在中的边的集合,为端点全部在中的边的集合。我们递归地解决两个子图和的最小生成树问题。最后,在边集合中选择横跨切割和的最小权重的边来将求出的......
  • IDEA 2024.3 EAP新特征早览!
    0前言IntelliJIDEA2024.3第一个EAP版本已发布,提前体验下一个重大版本的一部分改进。持续关注EAP更新,未来几周内将推出更多IntelliJIDEA新功能。尝试这些新功能,分享您的反馈,共同完善IDE。1AI助手1.1内嵌AI提示词推出一种全新方式,直接在编辑器中与AI助手......
  • leetcode232. 用栈实现队列
    leetcode232.用栈实现队列请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push、pop、peek、empty):实现MyQueue类:voidpush(intx)将元素x推到队列的末尾intpop()从队列的开头移除并返回元素intpeek()返回队列开头的元素booleanempt......
  • 【数据结构与算法 | 灵神题单 | 自底向上DFS篇】力扣965, 2331, 100, 1379
    1.力扣965:单值二叉树1.1题目:如果二叉树每个节点都具有相同的值,那么该二叉树就是单值二叉树。只有给定的树是单值二叉树时,才返回 true;否则返回 false。示例1:输入:[1,1,1,1,1,null,1]输出:true示例2:输入:[2,2,2,5,2]输出:false提示:给定树的节点数范围是 [1,......