NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

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

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

关注

评论

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

在 Windows 平台下安装与配置 MySQL 5.7.36

小齐写代码

当 BACnet 遇上 IoT,你将体验到不一样的大楼

华为云开发者联盟

云计算 后端 物联网 华为云 华为云开发者联盟

Java基础面试题【Spring】一

派大星

Java 面试题

大模型训练:自定义深度学习模型的策略与实践

百度开发者中心

大模型训练 文心千帆

万字长文详解低时延股票交易系统的设计

tyrande

交易所 事件溯源 股票系统 低延时

大模型训练中的Delta Tuning优化方法

百度开发者中心

人工智能 深度学习 大模型训练

腾讯云大数据ES:使用Elastic APM监控SpringBoot服务的最佳实践

腾讯云大数据

ES

OmniGraffle Pro for mac(专业图表绘制软件) v7.22.1永久激活版

mac

苹果mac Windows软件 OmniGraffle Pro 专业绘图软件

OpenHarmony页面级UI状态存储:LocalStorage

OpenHarmony开发者

OpenHarmony

iPaaS混合集成平台,打造数字化生态

RestCloud

数据同步 数字化升级 ipaas

专注二次元的 Niji 模型上线独立 APP;华为整体销量已超越苹果丨 RTE 开发者日报 Vol.68

声网

cad设计绘图工具:AutoCAD 2024 for Mac

展初云

设计 Mac软件 cad AutoCAD 2024下载

Sync Folders Pro for Mac(文件夹数据同步工具) v4.6.7永久激活版

mac

苹果mac Windows软件 Sync Folders Pro 文件夹同步工具

大模型训练对深度学习图片检测速度和精度的影响

百度开发者中心

深度学习 大模型训练 千帆大模型平台

Mac专业级的PDF编辑和管理软件:Acrobat Pro DC 2023

展初云

Mac软件 PDF编辑 PDF管理

Linux 如何进行内存分配

这我可不懂

Linux

Databend 开源周报第 115 期

Databend

7天狂揽 1.3w star 的 MetaGPT,他们的目标让软件公司为之一惊

鼎道智联

GPT

YouTube for mac(YouTube客户端)

iMac小白

YouTube客户端 YouTube mac

HTX 与 Zebec  Protocol 展开深度合作,并将以质押者的身份参与 ZBC Staking

西柚子

HTX 与 Zebec  Protocol 展开深度合作,并将以质押者的身份参与 ZBC Staking

大瞿科技

大模型训练:数据与算法的关键融合

百度开发者中心

人工智能 模型训练 大模型

DBeaverUE for Mac旗舰激活版 数据库管理软件

iMac小白

DBeaverUE下载 DBeaverUE破解版

「我在淘天做技术」一篇文章告诉你商品团队在做哪些有意思的事?

阿里技术

校园招聘 商品域

Mac电脑网页视频处理工具iTubeGo中文免激活版

mac大玩家j

视频处理工具 视频编辑器 在线视频工具

程序员常用的19款办公软件和开发工具推荐!

彭宏豪95

效率工具 开发工具 科技 办公软件 软件开发工具

Kafka架构详解

tyrande

kafka 系统设计 架构设计 消息列队

深耕全面预算管理 拥抱企业数字未来

智达方通

自动化 全面预算管理 全面预算管理系统

HarmonyOS音视频开发概述

HarmonyOS开发者

HarmonyOS

Java时间处理---Java8中时区相关类库介绍

程序员万金游

Java 面试 #java #程序员 #JavaSE

高效利用内存资源:掌握Redis内存管理与淘汰策略

树上有只程序猿

redis 内存管理

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