2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

JEP 481:作用域值 API 的第 3 个预览版随 JDK 23 发布,带来关键增强

  • 2024-08-12
    北京
  • 本文字数:1628 字

    阅读完需:约 5 分钟

JEP 481:作用域值API的第3个预览版随JDK 23发布,带来关键增强

JEP 481(作用域值第 3 个预览版)——之前称为范围局部变量(孵化)——提供了第三次预览。该版本只有一个变化,旨在从之前的一轮孵化和两轮预览之外获得额外的经验和反馈:随 JDK 22 交付的 JEP 464(作用域值第 2 个预览版)、随 JDK 21 交付的 JEP 446(作用域值预览版)以及随 JDK 20 交付的 JEP 429(作用域值孵化)。该特性支持在线程内部和线程之间共享不可变数据。


在 JDK 23 中重新预览的作用域值 API 修改了ScopedValue.callWhere方法。现在,这个方法的操作参数是一个函数式接口。它允许 Java 编译器推断是否可能抛出检查异常。因此,ScopedValue.getWhere这个方法就不再需要了,而且已经删除。在频繁共享数据的场景中,这会使代码更简洁,而且性能更好。


作用域值使方法能够与其调用者和子线程共享不可变数据。与线程局部变量相比,这可以简化数据流的管理和推断。而且,它们的空间和时间成本更低,特别是在与虚拟线程(JEP 444)和结构化并发(JEP 480)结合使用时。


不过,Java 1.2 中引入的线程局部变量一直是一个简化同一线程内方法间数据共享的传统方法。尽管已经使用了很长时间,但它还是有一些缺点。一个主要的问题是它们毫无约束的可变性,任何代码都可以随时更改线程局部变量的值,这可能导致潜在的不一致。另一个缺点是它们的寿命不受限制;如果开发人员忘记调用remove方法,值的保存时长可能会超过所需的时长,而这通常会导致内存泄漏。此外,跨线程继承线程局部变量会显著增加开销,因为每个子线程都必须为先前在父线程中写入的每个线程局部变量分配存储空间,这会对性能产生负面影响。


作用域值解决了这个问题,它确保数据是不可变的,并且只能在定义好的作用域中访问。这增强了安全性和性能。


为了说明作用域值的好处,考虑下这样一个 Web 框架,它的上下文需要在不同的方法之间共享,而又不需要显式地将其作为参数传递。使用线程局部变量,该框架可能是这样的:


class Framework {
private final static ThreadLocal<FrameworkContext> CONTEXT = new ThreadLocal<>();
void serve(Request request, Response response) { var context = createContext(request); CONTEXT.set(context); Application.handle(request, response); }
public PersistedObject readKey(String key) { var context = CONTEXT.get(); var db = getDBConnection(context); return db.readKey(key); }}
复制代码


使用作用域值,其实现会变得更加简洁、高效:


class Framework {
private final static ScopedValue<FrameworkContext> CONTEXT = ScopedValue.newInstance();
void serve(Request request, Response response) { var context = createContext(request); ScopedValue.runWhere(CONTEXT, context, () -> Application.handle(request, response)); }
public PersistedObject readKey(String key) { var context = CONTEXT.get(); var db = getDBConnection(context); return db.readKey(key); }}
复制代码


使用线程局部变量,当框架调用用户代码以及当用户代码回调框架方法时,不需要将FrameworkContext作为方法的参数进行传递。线程局部变量是作为一个隐藏的方法参数:线程调用Framework.serve中的CONTEXT.set。然后,Framework.readKey中的CONTEXT.get自动就可以看到CONTEXT的本地副本。实际上,ThreadLocal字段充当了一个键,用于查找当前线程的FrameworkContext值。另一方面,使用作用域值简化了这个过程。它消除了可变状态,并且确保上下文只能在runWhere方法定义好的范围内访问,从而提供了一种更健壮且性能更好的方法。总之,作用域值 API 显著增强了 Java 中跨方法和线程共享数据的方式,促进了更好的编码实践,并提高了应用程序的性能。它非常符合现代并发模型,特别是当虚拟线程出现之后,它为开发人员处理高并发应用程序提供了一个重要的选项。


原文链接:

https://www.infoq.com/news/2024/07/jep-481-enhanced-scoped-values/

2024-08-12 08:006037

评论

发布
暂无评论
发现更多内容

多客云 Ai 短视频批量剪辑矩阵系统:高效创作与智能管理的一体化解决方案

微擎应用市场

MyEMS:引领能源管理升级的全方位解决方案

开源能源管理系统

开源 能源管理系统

FinClip驱动中国应用全球出海的降本增效实践

xuyinyin

1688商品详情API:从数据获取到商业价值落地的全攻略

Noah

高达99.57%GPU利用率,Alluxio在MLPerf Storage v2.0基准测试中展现卓越性能

Alluxio

AI 数据 模型训练 分布式缓存 MLPerf

判断等保测评机构是否正规的小技巧你知道吗?

行云管家

等保 等保测评

TCL电子(01070.HK)2025年H1经调整归母净利润大幅增长62.0%

财见

企业一定要部署堡垒机吗?理由是什么?

行云管家

网络安全 堡垒机

速来!CodeBuddy IDE国内版公测开启!🎉

CodeBuddy

从 KOL 到 KOC:海外营销“去中心化”新趋势

Wolink

海外推广 沃链Wolink 达人营销

全面开放下载!Fabarta个人专属智能体免邀请码体验,功能重磅更新

Fabarta

人工智能 智能体

云速搭 AI 助理发布:对话式生成可部署的阿里云架构图

阿里巴巴云原生

阿里云 AI 云原生

2025物联网与RFID产业:万亿赛道的技术破局与市场重构

斯科信息

RFID技术 RFID产业

夜莺里如何引用标签和注解变量

巴辉特

Nightingale 开源监控 告警模板 告警变量

对于房企而言,国内最值得选的楼宇对讲品牌有哪些?

新消费日报

壹佳美容按摩养生上门服务平台

微擎应用市场

G端业务需求的高效管理——禅道实践中的“破局”与“避坑”

禅道项目管理

软件 软件需求管理 禅道项目管理 软件需求设计 需求管理软件

【HarmonyOS相机开发系列】折叠屏镜头切换优秀实践

最新动态

浩创云 AI 三合一系统:微擎部署助力抢占商业服务新蓝海

微擎应用市场

就在明天!8月26日丨EasyModel新品发布会等你来!

袋鼠云数栈

数字孪生 数字孪生技术 易知微 空间智能 EasyModel发布会

软件工程 + AI 不是 “硬凑”,3 步走通落地关键环节

行云创新

平台工程 AI 赋能软件工程 AI赋能研发

MyEMS:让能源管理从 “模糊粗放” 走向 “清晰可控”

开源能源管理系统

开源 能源管理系统

组局同城社交社区平台进群找搭子陪玩旅游

微擎应用市场

MyEMS:赋能能源精细化管理的数字化利器

开源能源管理系统

开源 开源能源管理系统

FinClip组件化方案实现App前端轻量化重构

xuyinyin

优猿酒吧社交小程序:多门店酒吧的数字化经营利器

微擎应用市场

RFID 标签在封闭空间漏扫?系统化应对策略解析

斯科信息

RFID标签

中国中铁回应尖扎黄河特大桥事故:舆情管理的危机与修复

沃观Wovision

舆情监测 沃观Wovision 舆情监测系统 中铁回应尖扎黄河特大桥

JEP 481:作用域值API的第3个预览版随JDK 23发布,带来关键增强_编程语言_A N M Bazlur Rahman_InfoQ精选文章