在
java中的@Retention注释的源代码中,@ Rettention在其定义中使用,如此可能.
甚至RetentionPolicy也设置为RUNTIME,那么如何在它未准备好运行之前执行它.
package java.lang.annotation; @Documented @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.ANNOTATION_TYPE) public @interface Retention { /** * Returns the retention policy. * @return the retention policy */ RetentionPolicy value(); }
解决方法
这不是真正的递归.它只不过是对“后来”后面的类分别接口的前向引用. Java允许使用前向引用.对此有各种限制(请参阅Java语言规范,例如第
8.3.2.2节) – 但这些限制都不适用于此处.
除此之外:请记住,这里没有特殊的编译步骤.编译器只是为Retention接口创建一个普通的类文件.但那时:编译器很可能拥有关于此接口的硬编码知识.如果使用RetentionPolicy.SOURCE,编译器将从编译的类文件中排除注释.这意味着编译器必须进行某种检查(以确定某些内容是否已注释并启用了SOURCE策略).
换句话说:编译器可能包含类似的内容
if (x instaceof Retention) ...
并且此代码存在于编译器中.编译其他注释时,上述工作正常,但在编译Retention接口本身时也可以正常工作.
但关键信息是:没有递归,只是前向引用.稍后定义使用的东西.