Java—注解

目录

一、注解的理解

二、基本的Annotation介绍

@Override使用说明

@Deprecated的说明

@SuppressWarnings各种值的说明

三、JDK的元注解

@Retention注解

@Target

@Documented

@Inherited注解


一、注解的理解

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

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

3.在JavaSE中,注解的使用目的比较简单,列入标记过时的功能,忽略警告等等。在JavaEE中注解占据了更重要的角色,例如用来配置应用程序的任何且切面,代替JavaEE旧版中所遗留的冗余代码和XML配置等

二、基本的Annotation介绍

说明:使用Annotation时要在其前面增加@符号,并把该Annotation当成一个修饰符使用。用于修饰它支持的程序元素

三个基本的Annotation:

1.  @Override:限定某个方法,是重写父类方法,该注解只能用于方法

2.  @Deprecated:用于表示某个程序元素(类,方法等)已过时

3.  @SuppressWarnings:抑制编译器警告

@Override使用说明

1. @Override表示指定重写父类的方法(从编译层面验证),如果父类没有该方法则会报错

2. 如果不写@Override注解,而父类仍有public void fly(){},仍然构成重写

3. @Override只能修饰方法,不能修饰其他包、类、属性等等

4. 查看@Override注释源码为 @Target(ElementType.METHOD),说明只能修饰方法

5. @Target是修饰注解的注解,称为元注解

public class Override_ {
    public static void main(String[] args) {

    }
}

class Father {
    public void fly() {
        System.out.println("Father fly()....");
    }
}

class Son extends Father {
    //解读
    //1. @Override注解放在fly方法上,表示子类的fly方法重写了父类的fly方法
    //2. 这里如果没有写@Override,还是重写了父类的fly方法
    //3. 如果你写了@Override注解,编译器就会检查该方法是否真的重写了父类的方法,
    //   如果重写了则编译通过,如果没有构成重写,则编译错误
    //4. @Override的定义
    //   解读:如果发现@interface 表示是一个注解类
    /*
        @Target(ElementType.METHOD)
        @Retention(RetentionPolicy.SOURCE)
        public @interface Override {
        }
     */
    @Override
    public void fly() {
        super.fly();
    }
}

@Deprecated的说明

1.用于表示某个程序元素(类、方法等)已过时

2.可以修饰方法、类、字段、包、参数等等

3.@Target(value={CONSTRUCTOR,FIELD,LOCAL_VARIABLE,METHOD,PACKAGE,PARAMETER,TYPE})

4.@Deprecated的作用可以做到新旧版本的兼容和过渡

public class Deprecated_ {
    public static void main(String[] args) {
        A a = new A();
        a.hi();
        System.out.println(a.n1);
    }
}
//解读
//1. @Deprecated修饰某个元素,表示该元素已经过时
//2. 即不再推荐使用,但是仍然可以使用
//3. 查看@Deprecated 注解类的源码
//4. 可以修饰方法、类、字段、包、参数等等
//5. @Deprecated可以做版本升级过度使用
/*
    @Documented
    @Retention(RetentionPolicy.RUNTIME)
    @Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})
    public @interface Deprecated {
    }
 */
@Deprecated
class A {
    @Deprecated
    public int n1 = 100;
    @Deprecated
    public void hi(){
    }
}

@SuppressWarnings各种值的说明

1.unchecked是忽略没有检查的警告

2.rawtypes是忽略没有指定泛型的警告(传参是没有指定泛型的警告错误)

3.unused是忽略没有使用某个变量的警告错误

4.@SuppressWarnings可以修饰的程序元素为:查看@Target

5.生成@SuppressWarnings时不用背,直接点击左侧的黄色提示,就可以选择(注意可以指定生成的位置)

@SuppressWarning 中的属性介绍以及属性说明

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,抑制与未用的程式码及停用的程式码相关的警告

package com.learn.annotation_;

import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.util.ArrayList;
import java.util.List;

import static java.lang.annotation.ElementType.*;
import static java.lang.annotation.ElementType.LOCAL_VARIABLE;



@SuppressWarnings({"rawtypes", "unchecked","unused"})
public class SuppressWarnings_ {
    //解读
    //1. 当我们不希望看到这些警告的时候,可以使用 @SuppressWarnings注解来抑制警告信息
    //2. 在{""}中,可以写入你希望抑制(不显示)警告的信息
    //3. 可以指定的警告类型有
    /*
        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,抑制与未用的程式码及停用的程式码相关的警告
     */
    //4. 关于@SuppressWarnings作用范围是和你放置的位置相关
    //   比如@SuppressWarnings放置在main方法,那么抑制警告的范围就是main
    //   通常我们可以放置在具体的语句、方法、类
    //5. 看看@SuppressWarnings源码
    //(1)放置的位置就是TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE
    //(2)该注解有数组 String[] values() 设置一个数组比如{"rawtypes", "unchecked","unused"}
    /*
        @Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})
        @Retention(RetentionPolicy.SOURCE)
        public @interface SuppressWarnings {
            String[] value();
        }
    */



//    @SuppressWarnings({"rawtypes", "unchecked","unused"})
    public static void main(String[] args) {
        List list = new ArrayList();
        list.add("jack");
        list.add("tom");
        list.add("mary");
        int i;
        System.out.println(list.get(1));
    }

    public static void f1(){
//        @SuppressWarnings({"rawtypes"})
        List list = new ArrayList();
        list.add("jack");
        list.add("tom");
        list.add("mary");
//        @SuppressWarnings({"unused"})
        int i;
        System.out.println(list.get(1));
    }
}

三、JDK的元注解

  • 元注解的基本介绍

JDK的元Annotation用于修饰其他Annotation

  • 元注解的种类

1.Retention:指定注解的作用范围,三种 SOURCE,CLASS,RUNTIME

2.Target:指定注解可以在哪些地方使用

3.Documented:指定该注解是否会在javadoc体现

4.Inherited:子类会继承父类注解

@Retention注解

说明:只能用于修饰一个Annotation定义,用于指定该Annotatio可以保留多长时间,@Retention包含一个RetentionPolicy类型的成员变量,使用@Retention时必须为该value成员变量指定值:

@Retention的三种值

1.RetentionPolicy.SOURCE:编译器使用后,直接丢弃这种策略的注释

2.RetentionPolicy。CLASS:编译器将把注解记录在class文件中,当运行Java程序时,JVM不会保留注解。这是默认值

3.RetentionPolicy.RUNTIME:编译器将把注解记录在class文件中当运行Java程序时,JVM会保留注解,程序可以通过反射获取该注解

@Target

说明:用于修饰Annotation定义,用于指定被修饰的Annotation能用于修饰哪些元素,@Target也包含一个名为value的成员变量

@Documented

说明:定义为Documented的注解必须设置Retention值为RUNTIME

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

@Inherited注解

说明:实际应用中使用较少,了解即可

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

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值