1、三种基本的Annotaton

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

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

@SuppressWarnings : 抑制编译器警告

@Override

class father{
public void fly(){}
}
class son extends father{
@Override
public void fly() {
super.fly();
}
}

解读

@Override表示son重写了fly方法

细节

  1. 如果没有@Override还是会重写fly方法
class father{
public void fly(){}
}
class son extends father{
public void fly() {
super.fly();
}
}
  1. 写了@Override注解,编译器就会去检查方法是否重写了父类方法,如果重写了,则编译通过。若没有重写,则编译错误。

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

//@Override底层代码
@Target(ElementType.METHOD)//ElementType.METHOD说明@Override只能修饰方法
@Retention(RetentionPolicy.SOURCE)
public @interface Override {
}

@Deprecated

public class Deprecatedtext {
public static void main(String[] args) {
father father1 = new father();
father1.fly();
}
}
@Deprecated
class father{
@Deprecated
public void fly(){}
}

解读

@Deprecated表示某个程序元素(类,方法等)已过时,会通过单词中间的横线提醒。表示不建议使用。

效果

细节

  1. 可以修饰方法,类,包,参数等等
//@Deprecated底层代码
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})//说明Deprecated能修饰方法,类,包,参数等等
public @interface Deprecated {
}
  1. @Deprecated的作用可以起到做新旧版本的兼容过渡

@SuppressWarnings

@SuppressWarnings("all")
class father{
public void fly(){}
}

解读

@SuppressWarnings注解可以用来抑制警告信息{""}写入你希望抑制的警告信息

效果



细节

1.@SuppressWarnings作用范围和你放置的位置相关

public class Enumtext {
@SuppressWarnings("all")//作用范围在main方法
public static void main(String[] args) {
father father1 = new father();
father1.fly();
}
}
@SuppressWarnings("all")//作用范围在father类
class father{
public void fly(){}
}
  1. 指定警告类型有

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

元注解

  1. Retention 指定注解的作用范围,三种SOURCE,CLASS,RUNTIME
  2. Target 指定注解可以在哪些地方使用
  3. Documented 指定该注解是否会在javadoc体现
  4. Inherited 子类会继承父类注解

Retention

Retention的三种值

  1. RetentionPolicy.SOURCE :编译器使用后,直接丢弃注释
  2. RetentionPolicy.CLASS: 编译器把注解记录在class文件中,当运行java时JVM不会保留注释
  3. RetentionPolicy.PUNTIME:编译器把注解记录在class文件中,当运行java时JVM保留注释

Retention案例

@Override底层(IDEA进入底层的快捷键为Ctrl+B)

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.SOURCE)//表示@Override在编译器使用后,直接丢弃注释
public @interface Override {
}

Target

Target的值

@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})
//   1.CONSTRUCTOR:用于描述构造器
    2.FIELD:用于描述域
    3.LOCAL_VARIABLE:用于描述局部变量
    4.METHOD:用于描述方法
    5.PACKAGE:用于描述包
    6.PARAMETER:用于描述参数
    7.TYPE:用于描述类、接口(包括注解类型) 或enum声明

Target案例

@Deprecated底层

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})//表示@Documented在这些地方可以写注解
public @interface Deprecated {
}

Documented

Documented案例

@Deprecated底层

@Documented//@Deprecated代码会被保存到生产的文档中
@Retention(RetentionPolicy.RUNTIME)
@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})
public @interface Deprecated {
}

Inherited

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

Java注解Annotaton的更多相关文章

  1. Java注解

    Java注解其实是代码里的特殊标记,使用其他工具可以对其进行处理.注解是一种元数据,起到了描述.配置的作用,生成文档,所有的注解都隐式地扩展自java.lang.annotation.Annotati ...

  2. 19.Java 注解

    19.Java注解 1.Java内置注解----注解代码 @Deprecated                                    //不推荐使用的过时方法 @Deprecated ...

  3. Java注解入门

    注解的分类   按运行机制分:   源码注解:只在源码中存在,编译后不存在 编译时注解:源码和编译后的class文件都存在(如@Override,@Deprecated,@SuppressWarnin ...

  4. java注解(Annotation)解析

    注解(Annotation)在java中应用非常广泛.它既能帮助我们在编码中减少错误,(比如最常见的Override注解),还可以帮助我们减少各种xml文件的配置,比如定义AOP切面用@AspectJ ...

  5. JAVA 注解的几大作用及使用方法详解

    JAVA 注解的几大作用及使用方法详解 (2013-01-22 15:13:04) 转载▼ 标签: java 注解 杂谈 分类: Java java 注解,从名字上看是注释,解释.但功能却不仅仅是注释 ...

  6. attilax.java 注解的本质and 使用最佳实践(3)O7

    attilax.java 注解的本质and 使用最佳实践(3)O7 1. 定义pojo 1 2. 建立注解By eclipse tps 1 3. 注解参数的可支持数据类型: 2 4. 注解处理器 2 ...

  7. paip.java 注解的详细使用代码

    paip.java 注解的详细使用代码 作者Attilax 艾龙,  EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/att ...

  8. JAVA 注解的几大作用及使用方法详解【转】

    java 注解,从名字上看是注释,解释.但功能却不仅仅是注释那么简单.注解(Annotation) 为我们在代码中添加信息提供了一种形式化的方法,是我们可以在稍后 某个时刻方便地使用这些数据(通过 解 ...

  9. 框架基础——全面解析Java注解

    为什么学习注解? 学习注解有什么好处? 学完能做什么? 答:1. 能够读懂别人写的代码,特别是框架相关的代码: 2. 让编程更加简洁,代码更加清晰: 3. 让别人高看一眼. spring.mybati ...

随机推荐

  1. 5_终值定理和稳态误差_Final Value Theorem & Steady State Error

  2. 自制jq分页插件

    由于第一次写jq插件,中间有借鉴别人的代码. (function(){ var ms = { fillHtml: function(obj, option) { obj.empty(); var to ...

  3. JavaScript の 内容属性(HTML属性attribute)和 DOM 属性(property)

    [博文]内容属性(HTML属性)和 DOM 属性 标签: 博文 JavaScript 粗略解读(与jQuery做对比) 内容属性(HTML属性) : attribute DOM 属性(Element属 ...

  4. React中Ref 的使用 React-踩坑记_05

    React中Ref 的使用 React v16.6.3 在典型的React数据流中,props是父组件与其子组件交互的唯一方式.要修改子项,请使用new props 重新呈现它.但是,在某些情况下,需 ...

  5. 【前端Talkking】CSS系列——CSS深入理解之line-height

    1.写在前面 两个多周的时间没有写文章了,手好痒好痒,趁着公司在装修,从上周末到本周都在家办公,同时公司的项目并不紧急,于是抽着时间梳理了一下CSS中关于行高line-height的理解,今天发布出来 ...

  6. 大数据学习之路之ambari配置(二)

    按照网上的教程配置,发现配置到hadoop虚拟机内存就开始不够了,心累

  7. 大数据学习之路之ambari的安装

    之前按照正常方式安装的hbase不能插入数据 所以今天来尝试下ambari能不能行 已经打了快照 如果不能还能恢复之前的样子

  8. c++对于c的拓展_引用的本质是指针常量

    本质:c++底层实现的指针常量(Type & ref =val; // Type *const ref =&val)

  9. c++对c的拓展_增强

    一:新增bool类型关键字:c中bool类型需要添加stdbool.h头文件,c++则可直接使用 void test(){ bool a=true; //c++可直接定义而c需添加头文件 true和f ...

  10. Linux---必备命令(2)

    进程相关命令 # 查看系统所有的进程 ps -ef ps -ef | grep vim # 过滤出vim有关的进程 ps -ef | grep vim # 过滤出22端口的信息 ps -tunlp | ...