Java注解之Retention、Documented、Inherited介紹
Retention注解
Retention(保留)注解說明,這種類型的注解會被保留到那個階段. 有三個值:
1.RetentionPolicy.SOURCE —— 這種類型的Annotations只在源代碼級別保留,編譯時就會被忽略
2.RetentionPolicy.CLASS —— 這種類型的Annotations編譯時被保留,在class文件中存在,但JVM將會忽略
3.RetentionPolicy.RUNTIME —— 這種類型的Annotations將被JVM保留,所以他們能在運行時被JVM或其他使用反射機制的代碼所讀取和使用.
示例5演示了 RetentionPolicy.RUNTIME 的聲明:
Java注解的示例1:
@Retention(RetentionPolicy.RUNTIME)
public @interface Test_Retention {
String doTestRetention();
}
在這個示例中, @Retention(RetentionPolicy.RUNTIME)注解表明 Test_Retention注解將會由虛擬機保留,以便它可以在運行時通過反射讀取.
Documented 注解
Documented 注解表明這個注解應該被 javadoc工具記錄. 默認情況下,javadoc是不包括注解的. 但如果聲明注解時指定了 @Documented,則它會被 javadoc 之類的工具處理, 所以注解類型信息也會被包括在生成的文檔中. 示例6進一步演示了使用 @Documented:
Java注解的示例2:
@Documented
public @interface Test_Documented {
String doTestDocument();
}
接下來,像下面這樣修改TestAnnotations類:
public class TestAnnotations {
public static void main(String arg[]) {
new TestAnnotations().doSomeTestRetention();
new TestAnnotations().doSomeTestDocumented();
}
@Test_Retention (doTestRetention="保留注解信息測試")
public void doSomeTestRetention() {
System.out.printf("測試注解類型 'Retention'");
}
@Test_Documented(doTestDocument="Hello document")
public void doSomeTestDocumented() {
System.out.printf("測試注解類型 'Documented'");
}
}
現(xiàn)在,如果你使用 javadoc命令生成 TestAnnotations.html文件,你將看到類似于圖1的結果.
從截圖可以看到,文檔中沒有 doSomeTestRetention() 方法的 annotation-type信息()方法. 但是, doSomeTestDocumented() 方法的文檔提供了注解的描述信息. 這是因為 @Documented標簽被加到了Test_Documented注解上. 之前的注解Test_Retention并沒有指定 @Documented 標記(tag).
Inherited 注解(這段可能有問題...)
這是一個稍微復雜的注解類型. 它指明被注解的類會自動繼承. 更具體地說,如果定義注解時使用了 @Inherited 標記,然后用定義的注解來標注另一個父類, 父類又有一個子類(subclass),則父類的所有屬性將被繼承到它的子類中. 在示例7中,你會看到使用 @Inherited 標簽的好處.
Java注解的示例3
首先,定義你的注解:
@Inherited
public @interface MyParentObject {
boolean isInherited() default true;
String doSomething() default "Do what?";
}
接下來,使用注解標注了一個類:
@MyParentObject
public Class MyChildObject {
}
正如你看到的,你不需要在實現(xiàn)類中定義接口方法. 因為使用 @Inherited標記,這些都自動繼承了. 如果你使用一種古老的方式定義實現(xiàn)類,會是什么樣子呢? 看看下面這張 古老的實現(xiàn)方式吧:
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;
}
}
看到的區(qū)別嗎? 可以看到,你必須實現(xiàn)父接口的所有方法. 除了isInherited()和從myParentObject doSomething()方法外,你還需要實現(xiàn) java.lang.Object的 equals(),toString()和hasCode()方法. 還有 java.lang.annotation.Annotation 類的 annotationType()方法. 不管你是不是想要實現(xiàn)這些方法,你必須在繼承的對象中包含這些.
結論
本文向你展示了如何通過使用JDK5的注解功能使開發(fā)更容易. 注解不直接影響程序的語義. 開發(fā)和部署工具可以以某種方式閱讀這些注解并處理它們,使用包含注解的程序可以替代額外的Java源文件、XML文檔或其他古老的構件. 使用注解可以使用更少的代碼完成同樣的事情,并且有更好的編譯時錯誤檢測機制. 注解的目的是花更少的時間在那些死硬無用的細節(jié)中,更多地關注業(yè)務邏輯規(guī)則. 本文是Java注解系列的第一部分. 在第二部分中,你將了解如何使用注解來開發(fā)一個簡單的Web應用程序. 最后,在第三部分中,你會看到一個包括多個數(shù)據(jù)庫表的復雜示例.
相關文章
JAVA Spring中讓人頭痛的JAVA大事務問題要如何解決你知道嗎
這篇文章主要介紹了Java Spring事務使用及驗證過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2021-09-09springBoot 項目排除數(shù)據(jù)庫啟動方式
這篇文章主要介紹了springBoot 項目排除數(shù)據(jù)庫啟動方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09每天練一練Java函數(shù)與算法Math函數(shù)總結與字符串轉換整數(shù)
這篇文章主要介紹了Java函數(shù)與算法Math函數(shù)總結與字符串轉換整數(shù),每天練一練,水平在不知不覺中提高,需要的朋友快過來看看吧2021-08-08Springboot+ElementUi實現(xiàn)評論、回復、點贊功能
這篇文章主要介紹了通過Springboot ElementUi實現(xiàn)評論、回復、點贊功能。如果是自己評論的還可以刪除,刪除的規(guī)則是如果該評論下還有回復,也一并刪除。需要的可以參考一下2022-01-01使用Java7的Files工具類和Path接口來訪問文件的方法
下面小編就為大家分享一篇使用Java7的Files工具類和Path接口來訪問文件的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-11-11解決MyBatis中模糊搜索使用like匹配帶%字符時失效問題
Mybatis是我們日常項目中經(jīng)常使用的框架,在項目中我們一般會使用like查詢作為模糊匹配字符進行搜索匹配,下面的Mapper.xml是我們使用like在項目中進行模糊匹配的常用方式,感興趣的朋友跟隨小編一起看看吧2021-09-09