第十天Java基础(注解)
1. JDK中预定义的注解
1.@Override - 检查该方法是否是重写方法。如果发现其父类,或者是引用的接口中并没有该方法时,会报编译错误。
2.@Deprecated - 标记过时方法。如果使用该方法,会报编译警告。
3.@SuppressWarnings(“all”) - 指示编译器去忽略注解中声明的警告。
2. 自定义的注解
public @interface MyAnn {//注解本质上是个接口,默认继承了Annotation接口
//注解中可以定义的类型
//1.基本数据类型
public abstract int age(); //赋值方式(age="")
//2.Stirng类型
String name() default "张三";//在赋值的时候可以选择默认
//3.枚举
//4.以上类型的数组
int [] ints(); //赋值方式(ints={1,2,3})
String value();//如果只有一个属性,且属性名叫value的时候,赋值可以省略value名称
}
3.元注解
@Retention - 标识这个注解怎么保存,是只在代码中,还是编入class文件中,或者是在运行时可以通过反射访问。
@Documented - 标记这些注解是否包含在用户文档中。
@Target - 标记这个注解应该是哪种 Java 成员。
@Inherited - 标记这个注解是继承于哪个注解类(默认 注解并没有继承于任何子类)
从 Java 7 开始,额外添加了 3 个注解:
@SafeVarargs - Java 7 开始支持,忽略任何使用参数为泛型变量的方法或构造函数调用产生的警告。
@FunctionalInterface - Java 8 开始支持,标识一个匿名函数或函数式接口。
@Repeatable - Java 8 开始支持,标识某注解可以在同一个声明上使用多次。
@Target(value={ElementType.TYPE,ElementType.METHOD,ElementType.FIELD})//只能作用与类
//中 1.TYPE作用于类 2.METHOD作用于方法上 3.FIELD作用于成员变量
@Retention(RetentionPolicy.RUNTIME)//注解被保留的阶段
@Documented//是否存在doc文档中
@Inherited //描写注解是否被子类继承
4. 解析注解
如何获取注解中的属性值
@Pro(className = "demo06.Demo02",methodName = "sleep")
public class Test02 {
public static void main(String[] args) throws Exception{
Class<Test02> aClass = Test02.class;//使用本类的class
//找到Pro接口/注解,意思是实现了Pro接口中的抽象方法,返回值为(className = "demo06.Demo02",methodName = "sleep")
Pro pro = aClass.getAnnotation(Pro.class);
//获取className、methodName
String className = pro.className();
String methodName = pro.methodName();
System.out.println(className);
System.out.println(methodName);
}
}
5. 用注解代替配置文件
@Pro(className = "demo06.Demo02",methodName = "sleep")
public class Test02 {
public static void main(String[] args) throws Exception{
Class<Test02> aClass = Test02.class;//使用本类的class
//找到Pro接口/注解,意思是实现了Pro接口中的抽象方法,返回值为(className = "demo06.Demo02",methodName = "sleep")
Pro pro = aClass.getAnnotation(Pro.class);
//获取className、methodName
String className = pro.className();
String methodName = pro.methodName();
System.out.println(className);
System.out.println(methodName);
//2.有了类与方法
Class bClass = Class.forName(className);//加载类文件
Object o = bClass.newInstance();//调用空参构造方法去创建对象
Method method1 = bClass.getMethod(methodName);//获取需要被执行的方法
method1.invoke(o);//调用方法
}
}