【ArchSummit架构师峰会】探讨数据与人工智能相互驱动的关系>>> 了解详情
写点什么

Java 值类型的当前状态

  • 2018-06-26
  • 本文字数:1321 字

    阅读完需:约 4 分钟

甲骨文一直在努力向 Java 中加入值类型,这项工作包含在 Valhalla 项目中,Valhalla 是“一个探索和孵化候选高级 Java 虚拟机和语言特性的地方”。InfoQ 之前已经报道了这个项目以及向Java 中引入值类型的工作进展。

值类型旨在成为未来Java 版本中的第三种数据类型,当前已有的两种类型分别是原始类型和对象引用。经常有人说,Java 值类型应该“写起来像类,用起来像int”。这意味着它们应该是一个复合数据类型(代码与类相似),只是少了标识,并且如果有可能的话不提供对象头部(像int 一样)。

以Java 平台目前的情况来看,运行环境不会提供这种对内存布局的底层控制形式——它可能类似于C 语言当中的struct,但JVM 并不支持。所以,在当前版本中,所有组合数据类型都必须通过引用来访问。

如果要将Java 平台扩展为包含值类型,那么自然会产生这样的问题:值类型是否可用作类型参数(type parameter)值。如果不是,那么这似乎大大限制了它们的用处。因此,值类型的设计一直包含这样的假设,即在增强的泛型中,值类型可以作为类型参数的值。

这与Java 类型系统缺少顶级类型(top type)有关——Object 和int 不存在共同的超类型。换句话说,Java 类型系统不是单根(single-rooted)的。由于这个原因,Java 泛型类型的类型参数只能是引用类型。如果可能引入值类型,那么就必须解决这个问题(并且还要考虑泛型的类型擦除)。

从Java 8 开始,其设计目标之一就是提高JDK 中某些引用类型可能会在后续版本中发展成为值类型的可能性,所以这也是需要考虑的一个设计约束。两个明显的候选例子是Optional 和LocalDateTime——它们都具有值类型所期望的属性。例如,它们都是不可变的,并且都具备了值类型语义,即当且仅当所有字段的值都相等时,两个对象才相等。

如果JDK 类型有可能演变为值类型,那么问题来了:值类型在类文件中应该怎样表示?在当前版本的JVM 中,引用类型为L ;,所以 Optional 使用描述符 Ljava/util/Optional; 来表示。在过去的几年中,为了确定在类文件中如何表示值类型,开发者们已经评审过不同的提案和设计方案。

甲骨文 JVM 架构师 John Rose 最近简要描述了过去的历史、已经尝试过的各种方案以及遇到的问题。

当前的方向继续使用与引用类型相同的描述符语法来描述值类型(而不是像Qjava/util/Optional; 这样)。这种方法具有保持向后兼容的优点,向后兼容从一开始就是Java 的首要设计原则。

但是,该设计存在一个问题,因为类型描述符实际上是一种不完整的描述,因为它不区分特定类型是否是真正的值类型。为了解决这个问题,目前的提议是对JVM 类文件格式进行扩展,增加一个新的片段(ValueTypes),该片段详细说明文件中的哪些类型实际上是值类型。John Rose 已经对此进行了详细的描述,不过 v​​alhalla-dev 邮件列表上仍然在针对一些细节问题进行热烈的讨论。Stephen Colebourne 和其他人最近还讨论了 Java 值类型的可空性(nullability)问题。

与此同时,实现方面的工作进展顺利,预计适用于 JVM 研究者、框架作者和喜欢跟字节码打交道的人的原型将很快推出。通常情况下,对于主要特性,甲骨文不会承诺在任何特定 Java 版本或特定日期交付预期功能。

查看英文原文 The Current State of Java Value Types

2018-06-26 05:404148
用户头像

发布了 731 篇内容, 共 433.7 次阅读, 收获喜欢 1997 次。

关注

评论

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

WorkPlus企业数字化转型的超级APP,All in one完美解决方案

WorkPlus

程序员职业规划-实践篇

吳先森321

程序人生 职业规划 求职

智能工厂关键技术应用(第一、二、三讲)

工赋开发者社区

《钢岚》今日首发,成为首款基于HarmonyOS NEXT开发的战棋新游

最新动态

19 | 散列表(中):如何打造一个工业级水平的散列表

鲁米

IT外包驻场加速企业IT创新

Ogcloud

外包 IT 外包公司 外包项目 IT 运维

喜讯!云起无垠上榜《成长型初创企业推荐10强》

云起无垠

NFT 市场开发:洞察、功能和成本综合指南

区块链软件开发推广运营

dapp开发 区块链开发 链游开发 NFT开发 公链开发

实用编程技巧:MybatisPlus结合groupby实现分组和sum求和

知识浅谈

MyBatisPlus Mybatis-Plus

世界第一!

天翼云开发者社区

云计算 性能测试

浅谈 SpringMVC 执行过程

是月月啊2023

Spring 配置解析

RocketMQ 如何保证消息不丢失

是月月啊2023

RocketMQ

.NET中有多少种定时器

快乐非自愿限量之名

.net 开发者 定时器

奇点云2023数智科技大会来了,“双12”直播见!

奇点云

操作系统 发布会 奇点云

麒麟云K8s调度优化之错误重调度

麒麟云

Kubernetes 云原生 容器云 银河麒麟 银河麒麟云原生操作系统

搜狐智能媒体基于腾讯云大数据 EMR 的降本增效之路

腾讯云大数据

EMR

搭乘“低代码”快车,引领食品行业数字化转型全新升级

优秀

低代码 数字化转型

DevOps|研发提效-敏捷开发之任务看板

laofo

DevOps Scrum 敏捷 敏捷开发 研发效能

软件测试/测试开发/人工智能丨利用ChatGPT编写测试用例

测试人

巧用静默,原来真的可以告警零误报!

观测云

监控告警 静默规则

Python终于可以操作Office了

程序员晚枫

Python 自动化办公 入门版

2023年 - 我的程序员之旅和成长故事

Leo

#技术人的2023总结

22 | 哈希算法(下):哈希算法在分布式系统中有哪些应用

鲁米

燃!中国电信天翼云黑科技为智慧海关建设插上云翅膀!

天翼云开发者社区

人工智能 云计算 海关科技装备博览会

2023工作总结怎么写?保姆级的年终总结万能公式来了,助你一臂之力!

彭宏豪95

互联网 职场 年终总结 在线白板 工作总结

实时3D渲染-定义、原理及应用

3DCAT实时渲染

实时渲染 实时云渲染

CAS原理,看这一篇就够了!

是月月啊2023

CAS Java 面试题

SQL FOREIGN KEY 约束- 保障表之间关系完整性的关键规则

小万哥

MySQL 数据库 sql 程序员 后端开发

亚信安慧AntDB数据库中级培训ACP上线,中国移动总部首批客户认证通过

亚信AntDB数据库

数据库 AntDB AntDB数据库

平台工程动态 Monthly News 2023-11

杨振涛

平台 平台工程 平台工程社区 PECommunity 内部开发者社区

不同类型的IT外包服务分别适合什么企业?

Ogcloud

外包 IT 外包公司 外包项目 IT 运维

Java值类型的当前状态_Java_Ben Evans_InfoQ精选文章