注解在springboot日常开发中使用的频率是很高的,官方为我们提供了很多注解,比如:@Autowired、@GetMapping等……
但是我们有些特定的需求官方提供的注解是没有的。我们可以自定义注解。
下面我们来了解一下自定义注解的过程。
一:元注解
Java为我们提供了几个元注解来自定义注解。分别是:
1) @Target:用于描述注解的使用范围(即:被描述的注解可以用在什么地方)
TYPE, // 类,接口(包括注解类型)或枚举声明
FIELD, // 字段声明(包括枚举常量)
METHOD, // 方法声明
PARAMETER, // 方法参数
CONSTRUCTOR, // 构造方法
LOCAL_VARIABLE, // 局部变量
ANNOTATION_TYPE, // 注解类型
PCKAGE, // 包
TYPE_PARAMETER,
TYPE_USE
2) @Retention:表示需要在什么级别保存该注释信息,用于描述注解的生命周期
取值
描述
作用范围
使用场景
SOURCE
表示注解只保留在源文件,当java文件编译成class文件,就会消失
源文件
只是做一些检查性的操作,,比如 @Override 和 @SuppressWarnings
CLASS
注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期
class文件(默认)
要在编译时进行一些预处理操作,比如生成一些辅助代码(如 ButterKnife)
RUNTIME
注解不仅被保存到class文件中,jvm加载class文件之后,仍然存在
运行时也存在
需要在运行时去动态获取注解信息
3) @Document:说明该注解将被包含在javadoc中
4) @lnherited:说明子类可以继承父类中的该注解
二:自定义注解
使用@interface自定义注解时,自动继承了java.lang.annotation.Annotation接口。
分析:
@interface用来声明一个注解,格式:public@interface注解名{定义内容}
其中的每一个方法实际上是声明了一个配置参数
方法的名称就是参数的名称
返回值类型就是参数的类型(返回值只能是基本类型,Class,String,enum)
可以通过default来声明参数的默认值
如果只有一个参数成员,一般参数名为value
注解元素必须要有值,我们定义注解元素时,经常使用空字符串,0作为默认值,
自定义注解分为两部分:
1:自定义注解
(1):只有一个参数的注解
// 只能在方法上使用
@Target(ElementType.METHOD)
// Runtime级别注解
@Retention(RetentionPolicy.RUNTIME)
@interface MyCustomAnnotation {
// 如果只有一个参数,直接用value就可以,可以添加默认值
String value() default "";
}
调用:
@GetMapping("get")
@MyCustomAnnotation("test")
public void myMethod() {
// 业务逻辑
Sy
标签:SpringBoot,自定义,参数,interface,注解,TYPE,class
From: https://blog.csdn.net/qq_39708228/article/details/143844904