博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java注解之Retention、Documented、Inherited介绍
阅读量:6967 次
发布时间:2019-06-27

本文共 2416 字,大约阅读时间需要 8 分钟。

hot3.png

最近研究多数据源问题,使用的是druid连接池,多数据源通过注解自动配置,使用这三个注解 @Retention @Documented @Inherited 自定义一个注解配置数据源

Retention注解:- Retention(保留)注解说明,这种类型的注解会被保留到那个阶段

有三个值:

1.RetentionPolicy.SOURCE —— 这种类型的Annotations只在源代码级别保留,编译时就会被忽略 2.RetentionPolicy.CLASS —— 这种类型的Annotations编译时被保留,在class文件中存在,但JVM将会忽略

3.RetentionPolicy.RUNTIME —— 这种类型的Annotations将被JVM保留,所以他们能在运行时被JVM或其他使用反射机制的代码所读取和使用. 示例1演示了 RetentionPolicy.RUNTIME 的声明: Java注解的示例1:

@Retention(RetentionPolicy.RUNTIME) public TestRetention {

    String doTestRetention();

}

在这个示例中, @Retention(RetentionPolicy.RUNTIME)注解表明 TestRetention注解将会由虚拟机保留,以便它可以在运行时通过反射读取.

Documented 注解:

Documented 注解表明这个注解应该被 javadoc工具记录. 默认情况下,javadoc是不包括注解的. 但如果声明注解时指定了 @Documented,则它会被 javadoc 之类的工具处理, 所以注解类型信息也会被包括在生成的文档中. 示例2进一步演示了使用 @Documented:

Java注解的示例2:

@Documented public @interface TestDocumented {

    String doTestDocument();

}

接下来,像下面这样修改TestAnnotations类:

public class TestAnnotations {

    public static void main(String arg[]) {

    new TestAnnotations().doSomeTestRetention();

    new TestAnnotations().doSomeTestDocumented();

}

@TestRetention (doTestRetention="保留注解信息测试")

public void doSomeTestRetention() { System.ou

t.printf("测试注解类型 'Retention'"); }

@Test_Documented(doTestDocument="Hello document")

public void doSomeTestDocumented()

{ System.out.printf("测试注解类型 'Documented'"); } }

现在,如果使用 javadoc命令生成 TestAnnotations.html文件,你将看到类似于图1的结果.

Inherited 注解 这是一个稍微复杂的注解类型. 它指明被注解的类会自动继承. 更具体地说,如果定义注解时使用了 @Inherited 标记,然后用定义的注解来标注另一个父类, 父类又有一个子类(subclass),则父类的所有属性将被继承到它的子类中. 在示例7中,你会看到使用 @Inherited 标签的好处.

Java注解的示例3

首先,定义你的注解:

@Inherited

public @interface MyParentObject {

    boolean isInherited() default true;

    String doSomething() default "Do what?";

}

接下来,使用注解标注了一个类:

@MyParentObject

public Class MyChildObject { }

正如你看到的,你不需要在实现类中定义接口方法. 因为使用 @Inherited标记,这些都自动继承了. 如果你使用一种古老的方式定义实现类,会是什么样子呢? 看看下面这张 古老的实现方式吧:

public class MyChildObject implements MyParentObject {

    public boolean isInherited() { return false; }

    public String doSomething() { return ""; }

    public boolean equals(Object obj) { return false; }

     public int hashCode() { return 0; }

    public String toString() { return ""; }

     public Class annotationType() { return null; }

 }

看到的区别吗? 可以看到,你必须实现父接口的所有方法.

除了isInherited()和从myParentObject doSomething()方法外,

你还需要实现 java.lang.Object的

equals(),

toString()

和hasCode()方法.

还有 java.lang.annotation.Annotation 类的

annotationType()方法. 不管你是不是想要实现这些方法,你必须在继承的对象中包含这些.

转载于:https://my.oschina.net/u/2971326/blog/1846175

你可能感兴趣的文章
ybg_auth 4.2 版本发布,基于微服务开发业务框架
查看>>
浏览器事件机制中事件触发三个阶段?
查看>>
Python数据分析之糗事百科第二弹
查看>>
[剑指offer] 二叉搜索树与双向链表
查看>>
Java集合框架源码解析之LinkedHashMap
查看>>
读《学习之道》— 放松点,有时候太勤奋也是一种病
查看>>
王者荣耀使用什么编程语言开发的?
查看>>
Kubernetes-离线部署Kubernetes 1.9.0
查看>>
实验吧---忘记密码了
查看>>
C/C++中int128的那点事
查看>>
JAVA中Sql时间格式与util时间格式转换
查看>>
前端概述及网页入门
查看>>
Java Servlet web.xml 配置详解
查看>>
javascript mvc 代码
查看>>
七牛镜像存储使用手册
查看>>
iOS学习笔记之 Objective-C (二)
查看>>
eclipse提交项目到github
查看>>
小米正式开源 Istio 管理面板 Naftis
查看>>
小白们不要慌,这里为你提供免费靠谱的python学习流程图
查看>>
利用种子文件对windows7的攻击-学习笔记
查看>>