一 、jdk 注解:
1.@override 覆盖的方法;
2. @Deprecated 方法已经过时了。
3. @supperessWarmings("deprecation") 忽略这个警告。
常见第三方注解:
spring 注解:@autowire @service @respository
mybatis 注解:@insertProvider @updateProvider @Options
二、注解分类
按运行机制分:
1.源码注解:(注解只在源码存在,在编译时消失)
2.编译时注解 (源码和.class文件都存在);jdk 注解都是编译时注解;
3.运行时注解:(源码和.class文件都存在,且在运行时还起作用,甚至影响运行逻辑的注解)如:@autowire;
按照来源注解分;
1.来自jdk注解;
2.来自第三方注解:(打交道最多的注解)
3.自定义注解;
元注解:给注解的注解称为元注解。
三、 自定义注解:
1.自定义注解的语法要求
1.1 使用@interface类关键字定义注解
成员以无参无异常方式声明;
可以使用default为成员指定一个默认值;
1.2 成员类型受限(合法的类型包括):基本数据类型+String,Class,Annotation,Enumeration)
如果注解只有一个成员,则该成员必须取名为value();在使用时可以忽略成员名和赋值号(=);
注解类可以没有成员,没有成员注解称为标识注解;
实例:
@Target({ElementType.METHOD,Element.Type})
// 注解的作用域
// METHOD(方法声明),FIELD(字段声明),CONSTRUCTOR(构造方法声明),LOCAT_VARIABLE(局部变量声),
// PACKAGE(包声明),PARAMETER(参数声明),TYPE(类接口)
@Retention(Retentionpolicy.RUNTIME)
// 注解的声明周期 有三个值:
// sources (只会在源码上显示,运行时消失)
// CLASS(编译时会记录到class中,运行时被忽略)
// RUNTIME (运行时存在,可以通过反射获取)
@Inherited // 允许子类继承
@Documented //生成javadoc时会包含注解的信息
public @interface Description{
String desc();
String author(); //定义成员变量
int age() default 18; //设置注解默认值。
}
1.3使用自定义注解
实例:接上面实例。
//<@注解名> (<成员变量1> = "成员值1",<成员名2> = <成员值2>, ...)
@Description(desc = " I am wangwang", author = "code boy" , age = 20)
public String handColor(){
return "yellow";
}
四、解析注解:
概念:通过反射获取类、函数或成员上的运行时注解信息,从而实现动态控制程序的运行的逻辑;
1.使用类加载器加载类
class c = class.forname("com.test.child");
2.找到类上面的注解
boolean isExist = c.isAnnotationPresent(Description.class);
if(isExist){
//拿到注解实例
Description d = (Description)c.getAnnotation(Description.class);
//打印类上面的注解值 获取方法上的注解值类似。
System.out.println(d.name);
}