自定义注解

suaxi
2020-11-27 / 0 评论 / 61 阅读 / 正在检测是否收录...

使用@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

评论 (0)

取消