一、java 注解开发
1、定义
注解(Annotation),也叫元数据。一种代码级别的说明。它是JDK1.5及以后版本引入的一个特性,与类、接口、枚举是在同一个层次。它可以声明在包、类、字段、方法、局部变量、方法参数等的前面,用来对这些元素进行说明,注释。
java总共有三种内置注解:
- @Override,它的作用是对覆盖超类中方法的方法进行标记,如果被标记的方法并没有实际覆盖超类中的方法,则编译器会发出错误警告。
- @Deprecated,它的作用是对不应该再使用的方法添加注解,当编程人员使用这些方法时,将会在编译时显示提示信息,它与javadoc里的@deprecated标记有相同的功能
- @SuppressWarnings, 关闭不当编译器警告信息
2、自定义注解
1、申明一个@interface类文件,它有点像接口定义,在注解内可以添加变量,使用default可以默认变量的值:
2、使用自定义注解:
3、注解可以添加值:
3、高级注解应用
1、@Target 注解,用来表示注解的使用范围:
public enum ElementType {
/** 表示类,接口,枚举,不能是注解 */
TYPE,
/** 字段上,包括枚举常量 */
FIELD,
/** 方法上 */
METHOD,
/** 方法的参数上 */
PARAMETER,
/** 构造函数上 */
CONSTRUCTOR,
/** 本地变量 */
LOCAL_VARIABLE,
/** 注解类型 */
ANNOTATION_TYPE,
/** java包上 */
PACKAGE,
/**
* 类型参数声明
* 1.8以后可用
*/
TYPE_PARAMETER,
/**
* 类型使用
*1.8以后可用
*/
TYPE_USE
}
2、@Retention 注解,表示需要在什么级别保存该注解信息
public enum RetentionPolicy {
/**
* Annotations are to be discarded by the compiler.
* 注解将被编译器丢弃
*/
SOURCE,
/**
* Annotations are to be recorded in the class file by the compiler
* but need not be retained by the VM at run time. This is the default
* behavior.
* 注释将由编译器记录在类文件中
*但在运行时不需要由VM保留。 这是默认值行为。
*/
CLASS,
/**
* Annotations are to be recorded in the class file by the compiler and
* retained by the VM at run time, so they may be read reflectively.
*注释将由编译器记录在类文件中,在运行时由VM保留,因此可以反射性地读取它们。
* @see java.lang.reflect.AnnotatedElement
*/
RUNTIME
}
RUNTIME是比较常用的
3.@Document 表示将注解记录在文档中
4.@Inherited 表示允许子类继承父类中的注解
4、读取注解中的值
1.首先定义一个注解:
Intercept.java
package com.demo.annotation;
import java.lang.annotation.*;
/**
* @author xyd
* @version V1.0
* @Package com.demo.common
* @Description:
* @date 2018/8/7 14:32
*/
@Target({ElementType.METHOD,ElementType.TYPE}) // 可以使用在方法和类头上
@Retention(RetentionPolicy.RUNTIME) // 运