本文最后更新于 2022年9月13日 中午
注解知识点
自定义注解
编写规则
- Annotation 型定义为 @interface,所有的 Annotation 会自动继承 java.lang.Annotation 这一接口,并且不能再去继承别的类或是接口。
- 参数成员只能用 public 或默认(default) 这两个访问权修饰。
- 参数成员只能用基本类型 byte、short、char、int、long、float、double、boolean 八种基本数据类型和 String、Enum、Class、annotations 等数据类型,以及这一些类型的数组。
- 要获取类方法和字段的注解信息,必须通过 Java 的反射技术来获取 Annotation 对象,因为你除此之外没有别的获取注解对象的方法。
代码示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target;
@Target(ElementType.FIELD) @Retention(RetentionPolicy.RUNTIME) public @interface FieldInfo { String description(); int length(); }
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
| import java.lang.reflect.Field;
public class FieldInfoTest {
@FieldInfo(description = "用户名", length = 10) private String username;
public static void main(String[] args) { Class<FieldInfoTest> c = FieldInfoTest.class;
for(Field f : c.getDeclaredFields()){ if(f.isAnnotationPresent(FieldInfo.class)){ FieldInfo annotation = f.getAnnotation(FieldInfo.class); System.out.println( "字段:[" + f.getName() + "]," + "描述:[" + annotation.description() + "]," + "长度:[" + annotation.length() +"]" ); } } }
}
|
输出:
字段:[username],描述:[用户名],长度:[10]