Java基礎元註解基本原理示例詳解
元註解
是負責對其它註解進行說明的註解,自定義註解時可以使用元註解。Java 5 定義瞭 4 個註解,分別是 @Documented
、@Target
、@Retention
和 @Inherited
。Java 8 又增加瞭 @Repeatable
和 @Native
兩個註解。這些註解都可以在 java.lang.annotation
包中找到。下面主要介紹每個元註解的作用及使用。
@Documented
@Documented 是一個標記註解,沒有成員變量。用 @Documented 註解修飾的註解類會被 JavaDoc 工具提取成文檔。默認情況下,JavaDoc 是不包括註解的,但如果聲明註解時指定瞭 @Documented,就會被 JavaDoc 之類的工具處理,所以註解類型信息就會被包括在生成的幫助文檔中。
IDEA Documented 文檔生成
Tools -> Generate JavaDoc
@Target
@Target 註解用來指定一個註解的使用范圍,即被 @Target 修飾的註解可以用在什麼地方。@Target 註解有一個成員變量(value)用來設置適用目標,value 是 java.lang.annotation.ElementType 枚舉類型的數組,下表為 ElementType 常用的枚舉常量。
類型 | 適用目標 |
---|---|
TYPE | 用於類、接口(包括註解類型)或 enum 聲明 |
FIELD | 用於成員變量(包括枚舉常量) |
METHOD | 用於方法 |
PARAMETER | 用於方法參數 |
CONSTRUCTOR | 用於構造器 |
LOCAL_VARIABLE | 用於局部變量 |
ANNOTATION_TYPE | 用於註解 |
PACKAGE | 用於包 |
TYPE_PARAMETER | 用來類型參數(JDK 1.8新增) |
TYPE_USE | 能標註任何類型名稱(JDK 1.8新增) |
@Retention
@Retention 描述註解的生命周期,也就是該註解被保留的時間長短。@Retention 註解中的成員變量(value)用來設置保留策略,value 是 java.lang.annotation.RetentionPolicy
枚舉類型。
RetentionPolicy 有 3 個枚舉常量,如下所示:
- SOURCE:在源文件中有效(即源文件保留);
- CLASS:在 class 文件中有效(即 class 保留);
- RUNTIME:在運行時有效(即運行時保留);
生命周期大小排序為 SOURCE < CLASS < RUNTIME
,前者能使用的地方後者一定也能使用。
如果需要在運行時去動態獲取註解信息,那隻能用 RUNTIME 註解,如 @Documented 註解;如果要在編譯時進行一些預處理操作,比如生成一些輔助代碼,就用 CLASS 註解,如 @NonNull 註解;如果隻是做一些檢查性的操作,則可選用 SOURCE 註解,如 @Override 和 @SuppressWarnings 註解。
@Inherited
@Inherited 是一個標記註解,用來指定該註解可以被繼承。使用 @Inherited 註解的 Class 類,表示這個註解可以被用於該 Class 類的子類。就是說如果某個類使用瞭被 @Inherited 修飾的註解,則其子類將自動具有該註解。
示例
創建一個自定義註解,代碼如下所示:
@Target({ ElementType.TYPE }) @Inherited @Retention(RetentionPolicy.RUNTIME) public @interface MyInherited { }
測試類代碼如下:
@MyInherited public class TestA { public static void main(String[] args) { System.out.println(TestA.class.getAnnotation(MyInherited.class)); System.out.println(TestB.class.getAnnotation(MyInherited.class)); System.out.println(TestC.class.getAnnotation(MyInherited.class)); } } class TestB extends TestA { } class TestC extends TestB { }
運行結果為:
@MyInherited()
@MyInherited()
@MyInherited()
@Repeatable
@Repeatable 是 Java 8 新增,它允許在相同的程序元素中重復註解,在需要對同一種註解多次使用時,往往需要借助該註解。Java 8 版本以前,同一個程序元素前最多隻能有一個相同類型的註解,如果需要在同一個元素前使用多個相同類型的註解,則必須使用註解“容器”。
示例
Java 8 之前的相同類型的註解做法:
public @interface Roles { Role[] roles(); } public @interface Role { String roleName(); } public class RoleTest { @Roles(roles = {@Role(roleName = "roleA"), @Role(roleName = "roleB")}) public String doString(){ return "MingYue Repeatable 測試"; } }
Java 8 之後增加瞭重復註解,使用方式如下:
public @interface Roles { Role[] value(); } @Repeatable(Roles.class) public @interface Role { String roleName(); } public class RoleTest { @Role(roleName = "roleA") @Role(roleName = "roleB") public String doString(){ return "MingYue Repeatable 測試"; } }
兩者不同的地方是,創建重復註解 Role 時加上瞭 @Repeatable 註解,指向存儲註解 Roles,這樣在使用時就可以直接重復使用 Role 註解。
@Native
@Native 註解修飾成員變量,則表示這個變量可以被本地代碼引用,常常被代碼生成工具使用。
以上就是Java基礎元註解基本原理示例詳解的詳細內容,更多關於Java 元註解的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- Java中的三種標準註解和四種元註解說明
- 一篇文章帶你入門java註解
- Java-Java5.0註解全面解讀
- Java元註解Retention代碼示例介紹
- 淺談sql_@SelectProvider及使用註意說明