注解
1.JDK中预定义的一些注解:
- @Override:检测被标注的方法是否来自父类(接口)
- @Deprecated:标示提醒所标注的内容已过时
- @SuppressWarnings:压制警告
- @SuppressWarnings("all) 压制所有警告
- 通常是写在类上面
2.自定义注解
- 格式:
public @interface 注解名称{}
- 本质:
- public interface 注解名称 extends java.lang.annotation.Annotation
- 所以注解本质就是一个接口,该接口默认继承Annotation接口
- 属性:接口中的抽象方法
- 要求:
- 1.方法的返回值类型
- 基本数据类型
- String
- 枚举
- 注解
- 以上类型的数组
- 2.定义属性在使用时需要给属性赋值
- 可以使用default关键字给属性默认值,那么定义时就可以不赋值
- 如果只有一个属性需要赋值,并且属性名称为value,则value可以省略,直接写值即可
- 数组赋值如果数组中只有一个值,则{}可省略
- 1.方法的返回值类型
@MyAnno(name = "Bob", age = 0)
@MyAnno_1(20)
@MyAnno_2(anno = @MyAnno_1(0), per = Person.P1, vaule = 0, strs = {"abc","xxx"})
public class AnnoDemo1 {
}
public @interface MyAnno {
String name();
int age();
String sex() default "男";
}
public @interface MyAnno_1 {
int value();
}
public @interface MyAnno_2 {
int vaule(); // 基本数据类型
Person per(); // 枚举类型
MyAnno_1 anno(); // 注解类型
String[] strs(); // 数组
}
3.元注解
概念: 描述注解的注解
分类:
- @Target:描述注解能够作用的位置
- ElementType取值:
- TYPE:可以作用于类上
- METHOD:可以作用于方法上
- FIELD: 可以作用于成员变量上
- ElementType取值:
- @Retention:描述注解被保留的阶段
- @Retention
- @Documented:描述注解是否被抽取到api文档中
- @Inherited:描述注解是否被子类继承
package day0306;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
// 表明可以作用在类上、方法上和成员变量上
@Target(value = {ElementType.TYPE,ElementType.METHOD,ElementType.FIELD})
@Retention(value = RetentionPolicy.RUNTIME)
// 以下两种作为了解即可
@Documented
@Inherited
public @interface MyAnno_3 {
}
package day0306;
@MyAnno_3() // 作用于类
public class AnnoTest {
@MyAnno_3() // 作用于成员变量
int a;
@MyAnno_3() // 作用于方法
void show() {
}
}