java 注解详细使用

java注解详细解析

注解的基本概念

  • 注解(Annotation)又叫标注,是从Java5开始增加的一种引用数据类型
  • 注解本质上就是代码中的特殊标记,通过这些标记可以在编译、类加载、 以及运行时执行指定的处理

注解的语法格式

访问修饰符 @interface 注解名称 {
	注解成员;
}
  • 自定义注解自动继承java.lang.annotation.Annotation接口。
  • 通过@注解名称的方式可以修饰包、类、 成员方法、成员变量、构造方 法、参数、局部变量的声明等

注解的使用方式

  • 注解体中只有成员变量没有成员方法,而注解的成员变量以“无形参的方 法”形式来声明,其方法名定义了该成员变量的名字,其返回值定义了该 成员变量的类型

  • 如果注解只有一个参数成员,建议使用参数名为value,而类型只能是八 种基本数据类型、String类型、Class类型、enum类型及Annotation类型

    /**
     * 自定义注解 若一个注解中没有任何成员 则这样的额注解叫做标记注解/标识注解
     */
    public @interface MyAnnotation {
        public String value() default "默认值"; // 声明一个String类型的成员变量 名字为value
        public String value2();
    }
    
  • 注解内部的参数值 成员参数名 = 成员数值,…

    @MyAnnotation(value = "hello",value2 = "你好") // 表示将注释MyAnnotation 贴在 Person 类中
    @MyAnnotation(value2 = "world")
    

元注解的概念

  • 元注解是可以注解到注解上的注解,或者说元注解是一种基本注解,但 是它能够应用到其它的注解上面。
  • 元注解主要有 @Retention(作用范围)、@Documented(文档)、@Target、@Inherited(继承)、 @Repeatable(可重复的)

元注解@Retention

  • @Retention 应用到一个注解上用于说明该注解的的生命周期,取值如下

  • RetentionPolicy.SOURCE 注解只在源码阶段保留,在编译器进行编译时 它将被丢弃忽视。

  • RetentionPolicy.CLASS 注解只被保留到编译进行的时候,它并不会被加 载到 JVM 中,默认方式

  • RetentionPolicy.RUNTIME 注解可以保留到程序运行的时候,它会被加载 进入到 JVM 中,所以在程序运行时可以获取到它们

    @Retention(RetentionPolicy.SOURCE) // 表示在下面注解在源代码中有效
    @Retention(RetentionPolicy.CLASS)  // 表示下面注解在字节码文件中有效 默认值
    @Retention(RetentionPolicy.RUNTIME)  // 表示下面注解在运行时有效
    

元注解@Documented

  • 使用javadoc工具可以从程序源代码中抽取类、方法、成员等注释形成一 个和源代码配套的API帮助文档,而该工具抽取时默认不包括注解内容

  • @Documented用于指定被该注解将被javadoc工具提取成文档

  • 定义为@Documented的注解必须设置Retention值为RUNTIME

    @Retention(RetentionPolicy.RUNTIME) 
    @Documented // 表示注解信息可以被javadoc工具 提取到API 文档中
    

元注解@Target

  • @Target用于指定被修饰的注解能用于哪些元素的修饰,取值如下

    注解取值表达含义
    ElementType.ANNOTATION_TYPE可以给一个注解进行注解
    ElementType.CONSTRUCTOR可以给构造方法进行注解
    ElementType.FIELD可以给属性进行注解
    ElementType.LOCAL_VARIABLE可以给局部变量进行注解
    ElementType.METHOD可以给方法进行注解
    ElementType.PACKAGE可可以给一个包进行注解
    ElementType.PARAMETER可以给一个方法内的参数进行注解
    ElementType.TYPE可以给类型进行注解,比如类、接口、枚举
    @Target({ElementType.TYPE, ElementType.CONSTRUCTOR, ElementType.FIELD, 			 
    ElementType.METHOD}) // @Target 参数时一维数组 所以 传参可以传入多个
    

元注解@Inherited

  • @Inherited并不是说注解本身可以继承,而是说如果一个超类被该注解标 记过的注解进行注解时,如果子类没有被任何注解应用时,则子类就继 承超类的注解

    @Inherited // 表示下面注解所修饰的类中的注解使用可以被子类继承
    

元注解@Repeatable

  • @Repeatable表示自然可重复的含义,从Java8开始增加的新特性

  • 从Java8开始对元注解@Target的参数类型ElementType枚举值增加了两个

  • 其中ElementType.TYPE_PARAMETER 表示该注解能写在类型变量的声明 语句中,如:泛型。

  • 中ElementType.TYPE_ USE 表示该注解能写在使用类型的额语句中

    /**
     * java8以前处理多个注解
     */
    public @interface ManTypes {
        ManType[] value();
    }
    
    /**
     * 自定义注解描述人物的角色
     */
    @Repeatable(value = ManTypes.class)
    public @interface ManType {
        String value() default "";
    }
    
    @ManType(value = "歌手")
    @ManType(value = "超人")
    public class Man {
    }
    

常见的预制注解

  • 预制注解就是Java语言自身提供的注解,具体如下:

    注解名称表达含义
    @author标明开发该类模块的作者,多个作者之间使用,分割
    @version标明该类模块的版本
    @see参考转向,也就是相关主题
    @since从哪个版本开始增加的
    @param对方法中某参数的说明,如果没有参数就不能写
    @return对方法返回值的说明,如果方法的返回值类型是void就 不能写
    @exception对方法可能抛出的异常进行说明
    @Override限定重写父类方法, 该注解只能用于方法
    @Deprecated用于表示所修饰的元素(类, 方法等)已过时
    @SuppressWarnings抑制编译器警告
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小白迷上java

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值