Java 自定义注解
自定义注解一般都需要与反射配合使用,自定义注解对自动解析及装载数据时非常实用的,如自动JSON数据解析、从数据库查询数据自动装载等。
使用@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类型里面的参数该怎么设定:
1、只能用public或默认(default)这两个访问权修饰.例如,String value();这里把方法设为defaul默认类型;
2、参数成员只能用基本类型byte,short,char,int,long,float,double,boolean八种基本数据类型和 String,Enum,Class,annotations等数据类型,以及这一些类型的数组.例如,String value();这里的参数成员就为String;
3、如果只有一个参数成员,最好把参数名称设为"value",后加小括号.例:下面的例子FruitName注解就只有一个参数成员。
四、自定义注解的demo
1、注解类
@Target(ElementType.FIELD) @Retention(RetentionPolicy.RUNTIME) public @interface DBColum { String value(); } |
2、使用注解
public class AnnotateDataBean { @DBColum("myName") private String name;
@DBColum("myData") private String data } |
3、解析注解-
private void parseAnnotate() { AnnotateDataBean annotateDataBean = new AnnotateDataBean(); Class clazz = annotateDataBean.getClass(); Field[] fields = clazz.getDeclaredFields(); for (Field field : fields) { DBColum dbColum = field.getAnnotation(DBColum.class); String fieldName = field.getName(); System.out.println("parseAnnotate()1 fieldName=" + fieldName); if (dbColum != null) { String annoFeldName = dbColum.value(); System.out.println("parseAnnotate()2 annoFeldName=" + annoFeldName); } } } |