java自定义注解
1.注解分类:
按运行机制分:
SOURCE源码注解:注解只在源码中存在,编译成.class文件就不存在了
CLASS编译时注解:注解在源码和.class文件都存在,但运行时会被移除
(@Override,@Deprecated,@SuppressWarnings)
RUNTIME运行时注解:表示这个注解会保留到运行时,甚至还会影响运行逻辑
(@Autowired)
按来源分:
内置注解(@Override,@Deprecated,@SuppressWarnings)
第三方注解
自定义注解
2.元注解(注解的注解):
@Retention
定义注解的生命周期,可选值为source、class、runtime
@Documented
文档化注解,会被javadoc工具文档化
@Inherited
注解是自动继承的,想让一个类和它的子类都包含某个注解,就可以使用它来修饰注解
@Target
Target通过ElementType来指定注解可使用范围的枚举集合
ElementType的用法
取值 | 注解使用范围 |
---|---|
METHOD | 可用于方法上 |
TYPE | 可用于类、接口、注解类型或枚举类型 |
ANNOTATION_TYPE | 可用于注解类型上(被@interface修饰的类型) |
CONSTRUCTOR | 可用于构造方法上 |
FIELD | 可用于域上 |
LOCAL_VARIABLE | 可用于局部变量上 |
PACKAGE | 用于记录java文件的package信息 |
PARAMETER | 可用于参数上 |
3. 自定义注解例子:
使用@interface自定义注解时,自动继承了java.lang.annotation.Annotation接口,由编译程序自动完成其他细节。在定义注解时,不能继承其他的注解或接口。@interface用来声明一个注解,其中的每一个方法实际上是声明了一个配置参数。方法的名称就是参数的名称,返回值类型就是参数的类型(返回值类型只能是基本类型、Class、String、enum)。可以通过default来声明参数的默认值。
自定义注解格式:
public @interface 注解名{注解体}
1.所有基本数据类型(int,float,boolean,byte,double,char,long,short)
2.String类型
3.Class类型
4.enum类型
5.Annotation类型
6.以上所有类型的数组
Annotation类型里面的参数该怎么设定:
第一,只能用public或默认(default)这两个访问权修饰.例如,String value();这里把方法设为defaul默认类型;
第二,参数成员只能用基本类型byte,short,char,int,long,float,double,boolean八种基本数据类型和 String,Enum,Class,annotations等数据类型,以及这一些类型的数组.例如,String value();这里的参数成员就为String;
第三,如果只有一个参数成员,最好把参数名称设为"value",后加小括号.例:下面的例子Name注解就只有一个参数成员。
注解元素的默认值
注解元素注意点:
注解元素必须有确定的值,要么在定义注解的默认值中指定,要么在使用注解时指定,非基本类型的注解元素的值不可为null。因此, 使用空字符串或0作为默认值是一种常用的做法。这个约束使得处理器很难表现一个元素的存在或缺失的状态,因为每个注解的声明中,所有元素都存在,并且都具有相应的值,为了绕开这个约束,我们只能定义一些特殊的值,例如空字符串或者负数,一次表示某个元素不存在,在定义注解时,这已经成为一个习惯
1.Name.java(姓名注解)
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
*
* @description:姓名注解
* @author: libl
* @date: 2018年5月12日
*/
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Name {
String value() default "";
}