java – 递归使用@Retention注释,它怎么可能?

前端之家收集整理的这篇文章主要介绍了java – 递归使用@Retention注释,它怎么可能?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
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接口本身时也可以正常工作.

但关键信息是:没有递归,只是前向引用.稍后定义使用的东西.

猜你在找的Java相关文章