百科问答小站 logo
百科问答小站 font logo



注解参数为什么不支持Object? 第1页

  

user avatar   rednaxelafx 网友的相关建议: 
      

感觉像是在设计Java语言层面的annotation功能时,受JVM当时直接支持的常量类型的限制而做的一个取舍。

我们可以看看JVM规范(Java SE 8版)的

4.7.16.1. The element_value structure

对annotation的element可以取的值在Class文件中的记录的规定。

首先,在Class文件里,所有原始类型、String、Class常量都是有特殊支持的,而对一般Object的“常量”则是不支持的,对enum常量也是不支持的。

Annotation的参数(element)也是一种编译时常量,必须能够被Class文件所支持的常量项所表述;所以它可以支持原始类型、String、Class常量是很直观的事,不需要对Class文件以及JVM动多少刀子。

但光支持这些类型对Java语言层面的新功能来说太憋屈了。好歹给支持个enum对不对?参数里还想放别的annotation值对不对?另外如果需要放一串同类型的值的话,还得支持数组对不对?

所以上面链接里提到的Class文件里的element_value结构就对这几种特殊的扩展情况做了特定的支持。仅此而已。这特定的支持的机制是无法泛化到支持一般的Object“常量”的。

===================================

今年刚开过的的JVM Language Summit 2016上,John Rose的VM Futures演讲还提到了希望未来能在Class文件里支持复杂对象类型的常量。等那个功能真的提上日程之后,题主这个疑问或许就能得到新的答案了——任意能合理的看作常量的对象类型都应该能作为annotation的参数值了。

演讲的录像:

youtube.com/watch?

(跟新常量类型相关的部分在31:30左右开始)




  

相关话题

  为什么全网甚至全中国找不到一个能轻松,清晰,简洁明了把java编程讲清楚的人? 
  一行 Java 代码(以分号结束)能实现什么丧心病狂的功能? 
  为什么java版本更新这么慢? 
  为什么java版本更新这么慢? 
  如果一定要在C++和JAVA中选择,是C++还是java? 
  针对 log4j 此次漏洞,应该引起我们哪些警示?利用工具的同时我们是不是应该更注重基础原理? 
  很多人都说 C# 语法怎么优雅,仅仅是因为 C# 的关键字多吗? 
  为什么 Python 工程师很少像 Java 工程师那样讨论垃圾回收? 
  c#中没有友元类那么这种设计是否不太合理,如何修改才能得到更好的方案? 
  大龄门外汉如何进入软件开发行业? 

前一个讨论
游戏中的动态模糊是什么概念?
下一个讨论
民众是否需要知道所有的真相?





© 2025-02-23 - tinynew.org. All Rights Reserved.
© 2025-02-23 - tinynew.org. 保留所有权利