使用@interface自定义注解时,自动继承了java.lang.annotation.Annotation接口
- @interface用来声明一个注解,格式:public @interface 注解名{定义的内容}
- 其中的每一个方法实际上是声明了一个配置参数
- 方法的名称就是参数的名称
- 返回值类型就是参数的类型(返回值只能说基本类型Class、String、int等)
- 可以通过default来声明参数的默认值
- 如果只有一个参数成员,参数名一般设置为value
- 注解元素必须要有值,我们定义注解元素时,经常使用空字符串,0作为默认值
package com.annotation.demo01;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* @Author suaxi
* @Date 2020/11/27 11:10
* 自定义注解
*/
public class Test01 {
//注解可以显示赋值,如果没有默认值,我们就必须给注解赋值
@MyAnnotation(name = "孙笑川",schools = {"xx大学,xx小学"})
public void test(){
}
//@MyAnnotation2(value = "药水哥")
@MyAnnotation2("药水哥")//注解中默认值为value的时候value可以省略不写
public void test2(){
}
}
@Target({ElementType.TYPE,ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotation{
//注解的参数:参数类型 + 参数名()
String name() default "";
int age() default 0;
int id() default -1; //如果默认值为-1,表示不存在
String[] schools();
}
@Target({ElementType.TYPE,ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotation2{
//如果只有一个参数成员,参数名一般设置为value
String value();
}
评论 (0)