Java基础复习——注解

什么是注解?

  • 插入到源码中用于某种工具处理的标签。

  • 注解(Annotation)也被称为元数据(Metadata),用于修饰解释 包、类、方法、属性、构造器、局部变量等数据信息。

  • 在Java中,注解是当作一个修饰符来使用的,它被置于备注解项之前,中间没有分号

  • 每一个注解的名称前面都加了@符号,类似Javadoc的注解,Javadoc注解出现在 /***...*/ 定界符的内部,而注解是代码的一部分。

  • 和注释一样,注解不影响程序逻辑,但注解可以被编译或者运行,相当于嵌入代码中的补充信息

定义注解

modifiers @interface AnnotationName {
    element declaration1
    element declaration2
    . . .
}

注解@interface不是接口是注解类
每个元素声明具有如下形式

type elementName();
// 或者
type elementName() default value;

举例:

// 例如,下面的注解具有两个元素

public @interface BugReport {
    String assignedTo() default "[none]"
    int severity = 0
}

每个注解具有下面的格式

@AnnotationName(elementName1=value1, elementName1 = value2, . . .)
// 举例
@BugReport(assignedTo="Harry", severity=10)

有两个特殊的快捷方式用来简化注解

  1. 没有指定元素(没有元素或者默认值),称为 标记注解

    @BugReport // <=> @Bugreport(assignedTo="[none]", severity=0)
    
  2. 单值注解,如果一个元素具有特殊名字 value,并且没有指定其他元素,可以忽略元素名和等号

    // ActionListenerFor 注解定义如下
    public @interface ActonListenerFor {
        String value();
    }
    // 可以书写为
    @ActionListenerFor("yellowButton")
    // 而不是
    @ActionListenerFor(value="yellowButton")
    

三个基本的Annotation

  1. @Override:限定某个方法,是重写父类方法,该注解只能用于方法
  2. @Deprecated:表示某个程序元素(类,方法等)已经过时
  3. @SuppressWarnings:抑制编译器警告

@Override

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.SOURCE)
public @interface Override {
}
  • @Override 表示会重写父类的方法(编译层面验证)如果父类没有这个方法则会报错
  • 只能修饰方法,不能修饰其他类、包、属性等(后面介绍)

@Deprecated

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})
public @interface Deprecated {
}
  • 修饰某个元素,表示该元素已经过时
  • 不推荐使用,但仍可以使用,用于版本过渡等

@SuppressWarnings

@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})
@Retention(RetentionPolicy.SOURCE)
public @interface SuppressWarnings {
        String[] value();
}
  • 当我们不希望看到某些警告的时候,可以使用该注解来抑制警告信息

  • 在{""}中可以写入希望抑制的警告信息

  • 可以指定警告信息

    all:抑制所有警告
    boxing:抑制与封装/拆装作业相关的警告
    cast:抑制与强制转型相关的警告
    dep-ann:抑制与淘汰注释相关的警告
    deprecation:抑制与淘汰相关的警告
    fallthrough:抑制与switch陈述式中遗漏break相关的警告
    finally:抑制与未传回finally区块相关的警告
    hiding:抑制与隐藏变数的区域变数相关的警告
    incomplete-switch:抑制与switch陈述式(enum、case)中遗漏项目相关的警告
    javadoc:抑制与javadoc相关的警告
    nls:抑制与非nls字符串文字相关的警告
    null:抑制与空值分析相关的警告
    rawtypes:抑制与使用raw类型相关的警告
    resource:抑制与使用Closeable类型的资源相关的警告
    restriction:抑制与使用不建议或禁止参照相关的警告
    serial:抑制与可序列化的类别遗漏serialVersionUID栏位相关的警告
    static-access:抑制与静态存取不正确相关的警告
    static-method:抑制与可能宣告为static的方法相关的警告
    super :抑制与置换方法相关但不含super呼叫的警告
    synthetic-access:抑制与内部类别的存取未最佳化相关的警告
    sync-override:抑制因为置换同步方法而遗漏同步化的警告
    unchecked:抑制与未检查的作业相关的警告
    unqualified-field-access:抑制与栏位存取不合格相关的警告
    unused:抑制与未用的程序码及停用的程序码相关的警告
    

元注解

  • 注解的注解(用来修饰其他的注解)

四种

@Retention

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Retention {
    RetentionPolicy value();
}
  • 只能修饰一个注解定义,指定该注解保留多长时间

  • 包含一个RetentionPolicy类型的成员变量,使用该注解时必须为该 value 成员变量指定值

    @Retention 的三种值

    1. @RetentionPolicy.SOURCE:编译器使用后,直接丢弃这种策略的注解
    2. @RetentionPolicy.CLASS:编译器把注解记录在class文件中,当运行java程序时,JVM不会保留注解,这是默认值
    3. @RetentionPolicy.RUNTIME:编译器把注解记录在class文件中,当运行java程序时,JVM会保留注解,程序可以通过反射获取该注解

@Target

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Target {
    ElementType[] value();
}

public enum ElementType {
    TYPE,
    FIELD,
    METHOD,  
    PARAMETER,
    CONSTRUCTOR,
    LOCAL_VARIABLE,
    ANNOTATION_TYPE,
    PACKAGE,
    TYPE_PARAMETER,
    TYPE_USE
}

修饰Annotation定义,用于指定被修饰的注解能用于修饰哪些程序元素

@Document

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Documented {
}

用于指定被该元注解修饰的注解类将被javadoc工具提取成文档,即在生产文档时,可以看到该注解

说明,定义为@Document的注解必须设置为Retention值为RUNTIME

@Inherited

@Documented
@Retention(RetentionPolicy.CLASS)
@Target({ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER, ElementType.LOCAL_VARIABLE})
public @interface Interned {
}

被它修饰的注解将具有继承性,如果某个类使用了被@Inherited修饰的注释,则其子类将自动具有该注解。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值