将配置直接写入到程序之中:Annotation
@Override
,@Deprecated
,@SuppressWarnings
等class Person5 {
public String say(){
return "人在说话!";
}
}
class Student5 extends Person5{
@Override // 明确表示是覆写的函数,名称保持一致
public String say() {
return "学生在说话!";
}
@Deprecated // 不建议使用的操作,使用会出现警告
public String getInfo(){
return "hello";
}
}
class test7{
@SuppressWarnings("deprecated")//压制警告信息
public static void main(String[] args){
Student5 s = new Student5();
System.out.println(s.say());
System.out.println(s.getInfo());
}
}
public @interface MyAnnotation名称 { }
//自定义Annotation
public @interface MyAnnotation{
public String key() default "Michael";
public String value() default "Ming";
public Color color() default Color.RED;//限定枚举的参数范围
public String[] url();
}
@MyAnnotation(color=Color.BLUE, key="Michael", value="Ming",
url={"https://michael.blog.csdn.net/","abc.xxx"})
class Info{
}
也是一个 Annotation,其取值是通过 RetentionPolicy (枚举)指定
//自定义Annotation
@Retention(value=RetentionPolicy.RUNTIME) // 运行的时候可见
@interface MyAnnotation{
public String key() default "Michael";
public String value() default "Ming";
public EnumDemo.Color color() default EnumDemo.Color.RED;//限定枚举参数范围
public String[] url();
}
也是一种 Annotation
@Target(value=ElementType.METHOD) // 只能在方法上使用
//@Target(value = {ElementType.METHOD, ElementType.TYPE}) // 多个选项
@Retention(value=RetentionPolicy.RUNTIME)
@interface MyAnnotation{
public String key() default "Michael";
public String value() default "Ming";
public EnumDemo.Color color() default EnumDemo.Color.RED;//限定参数范围
public String[] url();
}
也是一种 Annotation
@Documented
可以在使用类中加入文档注释,方便生成文档
/**
* 文档注释
*/
也是一种 Annotation,写了@Inherited
的 Annotation 才能被子类继承
@Inherited