注解
- java5开始支持,对程序元素(类.方法.字段.构造器)进行描述
- 一个特殊的接口,自定义的注解都是继承自java.lang.annotation.Annotation接口
- 注解的定义方式:@interface 注解的名称
如同如同枚举是一个特殊的类,默认继承java.lang.Enum
JDK中内置的注解
1: @Override 限定重写父类的方法 2: @Deprecated 标记已过时的成员,不推荐使用 3: @SuppressWarnings (all)--抑制所有类型的警告 4: @SafeVarargs 抑制堆污染警告 当一个方法中出现泛型和可变参数的时候,就可能出现该警告使用注解的位置和注解的参数传递为什么不同
元注解
元注解: 描述注解的注解.
@Retention :表示注解可以保存到那个时期(SIURCE,CLASS,RUNTIME), 保存的值在RetentionPolicy枚举类中, 因为要使用反射来赋予注解特殊的功能,所以需要保存到RUNTIME时期; @Target:表示注解可以贴到那些位置; @Documented:表示使用@Documented标注的标签会保存到API文档中; @Inherited :表示使用@Inherited标注的标签可以被子类继承到;
自定义注解
使用 @interface 定义注解
@Retention(RetentionPolicy.RUNTIME) // 保存时期 @Target({ElementType.TYPE,ElementType.METHOD})//贴到类上,方法上 public @interface 注解名{ //注解中定义元素,和接口中的方法一样 String name() default "will"; int age() default 10; } //注解支持的数据类型 基本数据类型 String Class 注解,枚举,数组 //在给注解传递值的时候不想指定元素名称常用操作:
getAnnotation(注解.class) ;获取指定注解 isAnnotationPresent(注解.class):判断程序上是否有注解 getDeclaredAnnotation();返回所有注解如果在给注解传值得时候不想指定元素名称,可以将元素名定义为value

本文详细介绍了Java注解的概念、定义方式、使用位置、参数传递及元注解的作用,并通过实例展示了如何自定义注解,以及在实际开发中如何合理运用注解来提高代码质量和效率。
27万+

被折叠的 条评论
为什么被折叠?



