注解的使用给我们很多的方便,我们有必要来了解一下注解的定义:
一般我们把注解分为3类:
1.源码注解:只存在.java文件中,编译时就不存在了(平时对代码的逻辑说明等)
2.编译时注解:注解在源码和.class文件如:@Override @Suppvisewarnings 等,他们只在编译时起作用,按照注解的指定来编译
3.运行时注解:在运行时期作用,如Spring中@Autowired在运行时会把对应的Bean注入到指定属性中。
/**
* @Target表示我们在那些地方可以使用此注解
* 参数有ElementType.METHOD 在方法上使用、ElementType.TYPE在类 接口 ElementType.CONSTRUCTOR 构造方法 ElementType.PACKAGE 包声明 ElementType.PARAMETER 参数声明 ElementType.LOCAL_VARIABLE 用于局部变量 ElementType.FILED 字段声明
*
* @Retention() 表示声明周期 SOURCE 只在源码显示 编译时被丢弃 RetentionPolicy.CLASS编译时会记录到class中,
* 运行时被忽略 RetentionPolicy.RUNTIME 运行存在,可以通过反射进行读取
*
* @Inherited 允许被继承
*/
@Target({ElementType.METHOD,ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
//定义属于我们自己的注解
public @interface DescriptionAnnuto{ //使用@interface关键字定义一个注解名字
//这里面的成员类型是受限的,只能是java的基本类型和 Annotation、Enumeration 如果声明 Map m();是非法的
//有一个规定:如果注解的成员变量只有一个那这个成员变量必须取名为value() 而使用的时候直接放入值如:@Description("val")
//这个注解可以没有成员,没有成员的注解我们成为“标识注解”
String desc();//成员以无参且无异常的声明方式
String info();
int age() default 23;//可以使用default为成员指定一个默认值
}
以上就完成了自己的注解