小白学JAVA之十二——注解

小白学JAVA之十二——注解

一. 注解的语法格式

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

二. 注解的使用方式

  • 注解体中只有成员变量没有成员方法,而注解的成员变量以“无形参的方法”形式来声明,其方法名定义了该成员变量的名字,其返回值定义了该成员变量的类型。
  • 如果注解只有一个参数成员,建议使用参数名为value,而类型只能是八种基本数据类型、String类型、Class类型、enum类型及Annotation类型。
public @interface MyAnnotation {
    public Direction value(); // 声明一个String类型的成员变量,名字为value   类型有要求
    public String value() default "123"; // 声明一个String类型的成员变量,名字为value
    public String value2();
}

三. 元注解

3.1概念

  • 元注解是可以注解到注解上的注解,或者说元注解是一种基本注解,但是它能够应用到其它的注解上面。
  • 元注解主要有@Retention、@Documented、@Target、@Inherited、@Repeatable。

3.2@Retention

  • @Retention 应用到一个注解上用于说明该注解的的生命周期,取值如下:
  • RetentionPolicy.SOURCE 注解只在源码阶段保留,在编译器进行编译时它将被丢弃忽视。
  • RetentionPolicy.CLASS 注解只被保留到编译进行的时候,它并不会被加载到JVM 中,默认方式。
  • RetentionPolicy.RUNTIME 注解可以保留到程序运行的时候,它会被加载进入到JVM 中,所以在程序运行时可以获取到它们。

3.3@Documented

  • 使用javadoc工具可以从程序源代码中抽取类、方法、成员等注释形成一个和源代码配套的API帮助文档,而该工具抽取时默认不包括注解内容。
  • @Documented用于指定被该注解将被javadoc工具提取成文档。
  • 定义为@Documented的注解必须设置Retention值为RUNTIME。

3.4@Target

  • @Target用于指定被修饰的注解能用于哪些元素的修饰,取值如下:
    在这里插入图片描述

3.5@Inherited

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

3.6@Repeatable

  • @Repeatable表示自然可重复的含义,从Java8开始增加的新特性。
  • 从Java8开始对元注解@Target的参数类型ElementType枚举值增加了两个:
  • 其中ElementType.TYPE_PARAMETER 表示该注解能写在类型变量的声明语句中,如:泛型。
  • 其中ElementType.TYPE_USE 表示该注解能写在使用类型的任何语句中。

四. 常见的预制注解

  • 预制注解就是Java语言自身提供的注解,具体如下:
    在这里插入图片描述
    在这里插入图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值