小伙伴,今天将开始java注解的学习。
学习java注解好处
- 能读懂别人的代码,特别是框架。
- 简化自己的代码
注解概念
java提供了一种原程序中的元素关联任何信息和任何元数据的途径和方法。
jdk自带注解
@Override//覆盖父类的方法
@Deprecated//过时
@SuppressWarnings()//忽略警告
java第三方注解
注解分类 ----按照运行机制分
- 源码注解--注解只在源码中存在,编译成class之后,就不存在。
- 编译注解--在class文件中还存在,也在源码中存在。
- 运行时注解--在运行时还起作用。
原注解:注解的注解。
自定义注解
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import javax.enterprise.inject.spi.Annotated;
import javax.lang.model.element.Element;
@Target({ElementType.METHOD,ElementType.TYPE})//@target表示元注解的作用域,可以有多个作用域。
//ElementType.METHOD 作用范围方法
//ElementType.TYPE 用于范围类接口
//ElementType.CONSTRUCTOR 作用范围构造函数
//ElementType.FIELD 作用范围字段
//ElementType.LOCAL_VARIABLE 作用范围局部变量
//ElementType.PACKAGE 作用范围包
//ElementType.PARAMETER 作用范围变量
@Retention(RetentionPolicy.RUNTIME) //元注解生命周期
//RetentionPolicy.RUNTIME 在运行时起作用
//RetentionPolicy.CLASS 在编译的时候起作用,运行时忽略
//RetentionPolicy.SOURCE 只在源码中起作用,编译时会丢
@Inherited //允许子注解继承
@Documented //生成javadoc会包含注解信息
public @interface Test1 {
//使用@interface作为关键字,来定义注解,注意这里不是接口!
String desc();//成员以无参无异常申明
int age() default 18; //成员可以有默认值
//注意成员的类型有限制,包括所有的基本类型,还有string,class,Annotation,Enumeration
//注解只有一个成员,成员民必须是value。
//注意可以没有成员,这种注解称为标识注解
}
使用注解
@Test1(desc="shuai",age=17) //后面是注解成员的值,一定要注意注解成员的类型,还有注解的作用域
解析注解
概念:通过反射获取类,函数,或成员运行时的注解信息,从而动态控制程序运行。
public class Connect {
public static void main(String[] args) {
try {
Class c = Class.forName("注解类的包名+使用注解的类名(被解析的类)");
//获取注解修饰类或接口的值
boolean b = c.isAnnotationPresent(Test1.class);//后面值是注解类,判断是否有这个注解
if(b){
Test1 t = (Test1) c.getAnnotation(Test1.class);// 拿到注解实例
System.out.println(t.desc());//这里是拿到注解修饰类的值
}
//获取注释修饰方法的值
Method[] method = c.getMethods();
for(Method m:method){
boolean b1 = m.isAnnotationPresent(Test1.class);
if(b1){
Test1 t = (Test1) c.getAnnotation(Test1.class);// 拿到注解实例
System.out.println(t.desc());//打印方法上注解的值
}
}
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}