java自定义注解

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);

             }

        }

    }

原文地址:https://www.cnblogs.com/tangxl/p/3591298.html