分类:java基础->元注解java
demo源码地址git
首先说明下,java 注解是在jdk1.5 以后出现的github
jdk1.5版本内置了三种标准的注解:编辑器
@Override,表示当前的方法定义将覆盖超类中的方法。ide
@Deprecated,使用了注解为它的元素编译器将发出警告,由于注解@Deprecated是不同意使用的代码,被弃用的代码。工具
@SuppressWarnings,关闭不当编辑器警告信息。继承
Java还提供了4中元注解,专门负责新注解的建立: 这就是要用的愿注解(用于定义注解的注解)接口
java 元注解定义:用于定义注解的注解,就是你想自定义注解要使用的注解生命周期
@Target 表示该注解用于什么地方,可能的值在枚举类 ElemenetType 中,包括: ElemenetType.CONSTRUCTOR----------------------------构造器声明 ElemenetType.FIELD --------------------------------------域声明(包括 enum 实例) ElemenetType.LOCAL_VARIABLE------------------------- 局部变量声明 ElemenetType.METHOD ----------------------------------方法声明 ElemenetType.PACKAGE --------------------------------- 包声明 ElemenetType.PARAMETER ------------------------------参数声明 ElemenetType.TYPE--------------------------------------- 类,接口(包括注解类型)或enum声明文档
@Retention 表示在什么级别保存该注解信息。可选的参数值在枚举类型 RetentionPolicy 中,包括:
RetentionPolicy.SOURCE ---------------------------------注解将被编译器丢弃 RetentionPolicy.CLASS -----------------------------------注解在class文件中可用,但会被VM丢弃 RetentionPolicy.RUNTIME VM-------将在运行期也保留注释,所以能够经过反射机制读取注解的信息。
首 先要明确生命周期长度 SOURCE < CLASS < RUNTIME ,因此前者能做用的地方后者必定也能做用。通常若是须要在运行时去动态获取注解信息,那只能用 RUNTIME 注解;若是要在编译时进行一些预处理操做,好比生成一些辅助代码(如 ButterKnife),就用 CLASS注解;若是只是作一些检查性的操做,好比 @Override 和 @SuppressWarnings,则可选用 SOURCE 注解。
@Documented 将此注解包含在 javadoc 中 ,它表明着此注解会被javadoc工具提取成文档。在doc文档中的内容会由于此注解的信息内容不一样而不一样。至关与@see,@param 等。
@Inherited 容许子类继承父类中的注解。
自定义注解实现见源码