一、内置注解
@Override : 重写 *
定义在java.lang.Override
@Deprecated:废弃 *
定义在java.lang.Deprecated
@SafeVarargs
Java 7 开始支持,忽略任何使用参数为泛型变量的方法或构造函数调用产生的警告。
@FunctionalInterface: 函数式接口 *
Java 8 开始支持,标识一个匿名函数或函数式接口。
@Repeatable:标识某注解可以在同一个声明上使用多次
Java 8 开始支持,标识某注解可以在同一个声明上使用多次。
@SuppressWarnings:抑制编译时的警告信息。 *
定义在java.lang.SuppressWarnings
三种使用方式:
1. @SuppressWarnings("unchecked") [抑制单类型的警告]
2. @SuppressWarnings("unchecked","rawtypes") [抑制多类型的警告]
3. @SuppressWarnings("all") [抑制所有类型的警告]
二、元注解
元注解的作用是负责注解其他注解,java中定义了四个标准的meta-annotation类型,他们被用来提供对其他annotation类型作说明。
- @Target:用来描述注解的使用范围(注解可以用在什么地方)
- 使用范围的取值可以在枚举类ElementType中找到。
- @Retention:表示需要在什么级别保存该注释信息,描述注解的生命周期。一般都是Runtime
- 声明周期的取值在枚举类RetentionPolicy中定义。
- 三个注解的声明周期长度:
Source(源码级别) < Class(类级别) < Runtime(运行时环境)
- @Document:说明该注解将被包含在javadoc中。
- @Inherited:说明子类可以继承父类中的该注解。
三、自定义注解
public class MetaAnnotation {
//使用对方法的注解
@MyAnnotation(name = "a", age = 2, id = 34)
public void test() {}
}
//元注解
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.CLASS)
@Inherited
@interface MyAnnotation{
//在自定义注解中定义的方法,实际上是在使用注解的时候输入的参数名称,默认的参数名是value
String name();
int age();
int id();
//或者使用default在定义时设定默认值,在使用注解时就无需赋值了
String[] likes() default {"dffw", "fwfew"};
}