自定义Annotation(二)上

简介: 注解Annotation 很强大,很重要,是不是想要自己能够编写注解呢?接下来,我们就可以尝试编写简单的注解了。

注解Annotation 很强大,很重要,是不是想要自己能够编写注解呢?


接下来,我们就可以尝试编写简单的注解了。


本文参考菜鸟编程文章: Java 注解(Annotation)


一. Annotation 架构简单了解


一.一 主要三大类


一.一.一 注解类 Annotation


package java.lang.annotation;
/**
 * @since   1.5
 */
public interface Annotation {
    boolean equals(Object obj);
    int hashCode();
   toString();
    Class<? extends Annotation> annotationType();
}


是最原始的那个注解类。


一.一.二 作用类型 ElementType


package java.lang.annotation;
public enum ElementType {
    TYPE,               /* 类、接口(包括注释类型)或枚举声明  */
    FIELD,              /* 字段声明(包括枚举常量)  */
    METHOD,             /* 方法声明  */
    PARAMETER,          /* 参数声明  */
    CONSTRUCTOR,        /* 构造方法声明  */
    LOCAL_VARIABLE,     /* 局部变量声明  */
    ANNOTATION_TYPE,    /* 注释类型声明  */
    PACKAGE             /* 包声明  */
}


是一个枚举,定义 注解的放置范围。


一.一.三 保留策略 RetentionPolicy


package java.lang.annotation;
public enum RetentionPolicy {
    SOURCE,            /* Annotation信息仅存在于编译器处理期间,编译器处理完之后就没有该Annotation信息了  */
    CLASS,             /* 编译器将Annotation存储于类对应的.class文件中。默认行为  */
    RUNTIME            /* 编译器将Annotation存储于class文件中,并且可由JVM读入 */
}


一.二 架构图


20200702195135224.png


Annotation 与 RetentionPolicy 是一对一的关系,与 ElementType 是一对多的关系。


Override,Deprecated 等都是 Annotation的子类。


一.三 内置子类作用


(引用于菜鸟编程)


Java 定义了一套注解,共有 7 个,3 个在 java.lang 中,剩下 4 个在 java.lang.annotation 中。


作用在代码的注解是


  • @Override - 检查该方法是否是重写方法。如果发现其父类,或者是引用的接口中并没有该方法时,会报编译错误。
  • @Deprecated - 标记过时方法。如果使用该方法,会报编译警告。
  • @SuppressWarnings - 指示编译器去忽略注解中声明的警告。


作用在其他注解的注解(或者说 元注解)是:


  • @Retention - 标识这个注解怎么保存,是只在代码中,还是编入class文件中,或者是在运行时可以通过反射访问。
  • @Documented - 标记这些注解是否包含在用户文档中。
  • @Target - 标记这个注解应该是哪种 Java 成员。
  • @Inherited - 标记这个注解是继承于哪个注解类(默认 注解并没有继承于任何子类)


老蝴蝶注:这个在创建新的注解时,非常有用。


从 Java 7 开始,额外添加了 3 个注解:


  • @SafeVarargs - Java 7 开始支持,忽略任何使用参数为泛型变量的方法或构造函数调用产生的警告。
  • @FunctionalInterface - Java 8 开始支持,标识一个匿名函数或函数式接口。
  • @Repeatable - Java 8 开始支持,标识某注解可以在同一个声明上使用多次。


老蝴蝶注:函数式编程时用的。


二. 创建简单注解 @interface


创建注解,就像创建类,接口一样简单,只不是 类是 Class, 接口是 interface, 而注解是 @interface.


注意,是小写,前面有一个 @


注解里面,只有属性, 没有方法。 @interface 就表示实现了 java.lang.annotation.Annotation 接口。


二.一 创建简单的注解


创建表 注解 Table


//创建表注解 
public @interface Table {
}


创建 Id 主键注解


public @interface Id {
}


创建 Column 列注解


public @interface Column {
}


在使用的时候, @Table, @Id, @Column 即可。


二.二 使用 注解


先创建一个简单的pojo, Person ,里面有 id,name,sex,age,desc 五个基本的属性, 并且有相应的构造和 setter,getter方法。


@Table
public class Person implements Serializable {
    @Id
    private int id;
    @Column
    private  String name;
    @Column
    private  char sex;
    @Column
    private int age;
    @Column
    private String desc;
}




相关文章
|
6月前
|
Java 编译器 程序员
JavaSE中注解(Annotation)详细介绍与实例
JavaSE中注解(Annotation)详细介绍与实例
62 0
|
安全 Java 编译器
一文带你全面深入理解Java注解Annotation
一文带你全面深入理解Java注解Annotation
266 1
一文带你全面深入理解Java注解Annotation
|
Java 开发者
annotation 实现 | 学习笔记
快速学习 annotation 实现,介绍了 annotation 实现系统机制, 以及在实际应用过程中如何使用。
annotation 实现 | 学习笔记
|
开发框架 Java 编译器
Java注解Annotation小结
Java注解Annotation小结
|
Java 开发者
反射取得 Annotation 信息|学习笔记
快速学习 反射取得 Annotation 信息
109 0
反射取得 Annotation 信息|学习笔记
|
前端开发 安全 Java
Java注解(Annotation):请不要小看我!(1)
Java注解(Annotation):请不要小看我!
117 0
Java注解(Annotation):请不要小看我!(1)
|
Java 开发者
自定义 Annotation | 学习笔记
快速学习 自定义 Annotation
111 0
|
前端开发 Java 编译器
Java注解(Annotation):请不要小看我!(2)
Java注解(Annotation):请不要小看我!
133 0
Annotation-自定义注解入门
Annotation-自定义注解入门
135 0