Java 注解
作用:对程序作出解释,可以被其他程序读取
格式:以@符号开头,部分注解含有参数
内置注解:
@Override-重写
@Deprecated-不推荐使用
@SuppressWarnings-镇压警告,取值有all, unchecked, deprecation等
元注解:负责解释其他注解的注解
@Target-描述注解使用范围,取值有TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE等
@Retention-描述注解生命周期,SOURCE<CALSS<RUNTIME
@Documented-说明该注解将被包含在javadoc中
@Inherited-说明子类可以继承父类中的该注解
自定义注解:
// 自定义注解
@Target(value = {ElementType.METHOD,ElementType.TYPE}) // 规定使用在方法及类上
@Retention(value = RetentionPolicy.RUNTIME) // 表示注解在运行时仍然有效
@Documented // 注解将被包含在javadoc中
@Inherited // 子类可以继承父类中的该注解
public @interface MyAnnotation{
}
实例:
public class Test {
// 使用自定义注解,如果参数没有默认值,必须赋值
@MyAnnotationTest1(name = "小王")
public void test1() {
}
// 使用自定义注解,如果参数为value,则可省略
@MyAnnotationTest2("小张")
public void test2() {
}
}
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotationTest1 {
// 参数格式: 参数类型 参数名 ();
String name();
int age() default -1; // 如果默认值为-1,代表不存在
String[] str() default {"你好", "HELLO"};
}
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotationTest2 {
String value();
}