为什么Java 7钻石运算符不能与匿名类一起使用?

 负能量包子玻璃包各负磁场宣泄区 发布于 2023-01-19 19:23

考虑这个尝试实例化某些Lists的Java代码:

List list1 = new ArrayList();
List list2 = new ArrayList<>();
List list3 = new ArrayList() { };
List list4 = new ArrayList<>() { };
List list5 = new ArrayList() { };

list1并且list2很简单; list2在Java 7中使用新的菱形运算符来减少不必要的类型参数重复.

list3list1使用匿名类的变体,可能会覆盖一些方法ArrayList.

list4尝试使用菱形运算符,类似于list2,但这是一个编译错误,消息'<>'不能与匿名类一起使用.

list5产生一个错误,证明编译器知道实际需要什么类型.错误消息是类型不匹配:无法从新的ArrayList (){}转换为List

那么,随着声明list4,为什么钻石运算符不能用于匿名类?这里有一个类似的问题,接受的答案包含JSR-334的以下解释:

不支持使用带有匿名内部类的菱形,因为这样做通常需要扩展类文件签名属性以表示不可表示的类型,事实上的JVM更改.

我需要一些帮助来理解推理.为什么显式类型与相同且明显容易推断的类型需要在生成的类文件中有任何差异?"一般这样做"会涵盖哪些难以处理的用例?

这是什么原因?

assylias.. 21

这在"项目硬币"邮件列表中进行了讨论.实质上(强调我的):

在内部,Java编译器在一组更丰富的类型上运行,而不是那些可以在Java程序中显式写下的类型.无法在Java程序中编写的编译器内部类型称为不可表示的类型.由于钻石使用的推断,可以出现不可表示的类型.因此,不支持使用具有匿名内部类的菱形,因为这样做通常需要扩展类文件签名属性以表示不可表示的类型,事实上的JVM更改.只要推断类型是可表示的,在创建匿名内部类时,未来平台版本可以允许使用菱形是可行的.

请注意,它在Java 8中也不受支持,但将作为Java 9中的新功能("Milling Project Coin"的第3项)包含在内.

1 个回答
  • 这在"项目硬币"邮件列表中进行了讨论.实质上(强调我的):

    在内部,Java编译器在一组更丰富的类型上运行,而不是那些可以在Java程序中显式写下的类型.无法在Java程序中编写的编译器内部类型称为不可表示的类型.由于钻石使用的推断,可以出现不可表示的类型.因此,不支持使用具有匿名内部类的菱形,因为这样做通常需要扩展类文件签名属性以表示不可表示的类型,事实上的JVM更改.只要推断类型是可表示的,在创建匿名内部类时,未来平台版本可以允许使用菱形是可行的.

    请注意,它在Java 8中也不受支持,但将作为Java 9中的新功能("Milling Project Coin"的第3项)包含在内.

    2023-01-19 19:27 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有