内置注解:
@Override:表示一个方法声明打算重写超类中的另一个方法声明。
@Deprecated:可以用于修饰方法,属性、类,表示不鼓励程序员这样去使用这样的元素,通常是因为危险或者有更好的选择。也就是废弃的方法属性和类。
使用这个注解的时候会多一条杠杠,表示不推荐使用。
@SuppressWarnings:抑制编译时的警告信息,这个与前两个注释不同,你需要添加一个参数才可以正确的使用,这些参数都是已经定义好了的,我们选择即可。
元注解:
负责解释其他注解,java定义了四个标准的meta-annotation类型,他们被用来提供对其他annotation类型作说明。
@Target:用于描述注解的使用范围
@Target(value = {ElementType.METHOD,ElementType.TYPE})
@Retention:表示我们的注解在什么地方还有效,只有三个值,runtime,sources,class
runtime>class>sources
一般来说都是使用runtime
@Documented:表示是否将我们的注解生成在javadoc中
@Inherited:表示子类可以继承父类中的该注解
自定义注解:
使用@interface来自定义注解
@Target(value = {ElementType.METHOD,ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotation{
}
注解的参数:注解的类型+参数名();
和普通java类不一样,必须要加()
可以通过default来声明参数的默认值。
如果参数没有给默认值,就必须显示的传递参数
如果只有一个参数,通常使用value来作为参数名。
public class Test02 {
//注解可以显示赋值,如果没有默认值就必须显示赋值
@MyAnnotation(name= "yf",school = {"三中","xju"})
public void test(){
}
}
@Target(value = {ElementType.METHOD,ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotation{
//注解的参数:注解的类型+参数名();
String name() default "";
int age() default 20;
int id() default -1;//默认值为-1,表示不存在
String[] school() default {"清华","北大"};
}