Java annotation cannot access protected static fields from upper class

后端 未结 4 699
逝去的感伤
逝去的感伤 2021-01-20 00:00

Is this code valid?

public abstract class A {
   protected static final String c = \"my const\";
}

@myAnnotation(value=A.c)
public class B extends A {

}


        
相关标签:
4条回答
  • 2021-01-20 00:20

    I think I see what is happening here. An instance of an annotations is effectively an interface with a unique static initializer. The only things the annotation spec adds on top are syntactic sugar and a link to the method, class or field. So when you type value=c.A that is almost like adding a static initilizer to the annotation. The annotation is not a subclass of A, so access is denied. Protected access includes package access, so when you move A into the same package as B the annotation is also in the same package as A. It gets access. Very good question and I think the behavior should be the same for both compilers. I think Eclipse will let you customize what it treats as an error so you might be able to make them agree to both use the undesirable, more restrictive behavior.

    0 讨论(0)
  • 2021-01-20 00:26

    This code will compile only if both A and B belong to the same package.

    0 讨论(0)
  • 2021-01-20 00:30

    Thanks to the comment from @adranale I found a different answer in the Java Language Specification section on Access Control. I don't think it should work this way, but the relevant text regarding "protected" reads

    Let C be the class in which a protected member m is declared. Access is permitted only within the body of a subclass S of C.

    The body of a class is all the code in curly brackets. Class anotations are outside the curly brackets, so they don't have access. Interestingly, this logic would not apply to method, parameter, field or local variable annotations which are inside the class body.

    0 讨论(0)
  • 2021-01-20 00:33

    The Annotation you are trying to fill with the "const" tries to access the class from outside by using protected that can't work. Eclipse uses it's own compiler so you should try to make clean rebuild in Eclipse to see if it's working. I assume it will not.

    0 讨论(0)
提交回复
热议问题