速来报名!AICon北京站鸿蒙专场~ 了解详情
写点什么

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:404300
用户头像

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

关注

评论

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

上手体验!如何借助龙蜥实验室快速部署 Web 应用?

OpenAnolis小助手

开源 国产操作系统 web服务器

一文全面掌握大数据关联与汇聚

云智慧AIOps社区

redis Clickhouse flink sql 大数据开发

【C语言】一篇速通操作符

謓泽

C语言 操作符 3月月更

Kafka中指定副本为Leader的三种实现方式

石臻臻的杂货铺

kafka 运维

高性能图计算系统 Plato 在 Nebula Graph 中的实践

NebulaGraph

图数据库 图计算 分布式图数据库

web前端培训:Vue3 调度系统的深度剖析

@零度

Vue 前端开发

如何获取 Docker 容器的 IP 地址

AlwaysBeta

Docker 容器

java培训:MyBatis的架构与原理分析

@零度

mybatis JAVA开发

会声会影2022脸部索引功能详解

懒得勤快

IOS技术分享| anyLive 开源项目

anyRTC开发者

ios 音视频 移动开发 视频直播 开源demo

智汇华云 | Kubernetes多集群管理方案kubefed原理解析

华云数据

云计算 华云数据 虚拟云

《隐私计算》重磅发布,全面、系统论述数据要素安全流通价值

博文视点Broadview

混合云管平台排名您知道吗?看这里!

行云管家

混合云 云管

云原生网络利器--Cilium 总览

Daocloud 道客

ebpf cilium 云原生网络 容器网络方案

EMQ 正式成为 OASIS 最高级别成员,主导推进物联网协议标准化应用

EMQ映云科技

开源 物联网 ibm mqtt OASIS

大数据培训:Spark高频面试题汇总

@零度

大数据 spark

微服务身份认证需求下的私钥托管痛点与破局

全象云低代码

微服务 低代码 身份认证 鉴权 密钥

从Nacos到完全自研|得物的注册中心演进之路

得物技术

架构 raft 注册中心 实例 兼容性测试

数仓中长跳转问题复现及解决方案

华为云开发者联盟

寄存器 GaussDB(DWS) 长跳转 编译器O2

脱颖而出!OceanBase 入选 2021“科创中国”开源创新榜单

OceanBase 数据库

数据库 分布式 OceanBase 开源 科创中国

2022年的SaaS行业,钱往哪里去?

ToB行业头条

Camtasia Studio2022激活码序列号

茶色酒

Camtasia Studio2022

始于信任 忠于专业|DataPipeline收到一封来自山东城商行联盟的感谢信

DataPipeline数见科技

Web 键盘输入法应用开发指南 (3) —— 输入法事件

天择

JavaScript 键盘 输入法 3月月更

2022年数据库审计厂家就选行云管家!功能强大!

行云管家

数据库 网络安全 数据库审计

《重构 JavaScript》读后感和部分摘录

道道里

前端 测试 重构

2022,你的团队距离持续部署还有多远?| 研发效能提升36计

阿里云云效

阿里云 云原生 持续部署 研发团队 研发

DM 中 relay log 性能优化实践丨TiDB 工具分享

PingCAP

Tuxera2022mac读写硬盘U盘工具

茶色酒

Tuxera2022

首发|Clusterpedia 0.1.0 四大重要功能

Daocloud 道客

开源项目 多云管理 K8s 多集群管理 多云资源复杂检索

2022年1月娱乐直播行业用户洞察:行业格局稳定,内容运营精细化

易观分析

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