原文地址:http://tutorials.jenkov.com/java-reflection/annotations.html
=====================================================================================
使用Java反射機制,在執行時你可以訪問到Java類中所附屬的一些註解。下面是本文所涵蓋的主題列表:
- What are Java Annotations? (什麼是Java註解)
- Class Annotations (類註解)
- Method Annotations (方法註解)
- Parameter Annotations (引數註解)
- Field Annotations (欄位註解)
=====================================================================================
- What are Java Annotations?
註解是Java 5的一個新特性。註解是一種可以寫到程式碼中的註釋或者後設資料。這些註解可以在編譯時由預編譯工具進行處理,或者在執行時通過Java反射處理。下面是一個類註解的例子:
@MyAnnotation(name="someName", value = "Hello World") public class TheClass { }
類TheClass有一個註解@MyAnnotation。定義註解就和定義介面一樣。下面是一個定義註解MyAnnotation的例子:
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface MyAnnotation { public String name(); public String value(); }
在interface之前加一個@符號來表示它是一個註解。一旦你定義了一個註解之後,你可以在程式碼中用它,和之前的例子一樣。
在註解的定義中,@Retention(RetentionPolicy.RUNTIME)和@Target(ElementType.TYPE)這兩個註解指定了如何去使用它們。
@Retention(RetentionPolicy.RUNTIME)表示該註解可以在執行時通過Java反射訪問。如果你沒有設定該指令,該註解在執行時就不會被儲存,那麼也就不能通過Java反射來使用。
@Target(ElementType.TYPE)表示該註解只能被用於型別上(如類、介面)。你也可以指定METHOD或者FIELD,或者你也可以省略不寫,即該註解可以被用在類、方法和欄位上。
關於Java註解更詳細的介紹在Java Annotation tutorial中。
=====================================================================================
- Class Annotations
你可以在執行時訪問類、方法或欄位的註解。下面是一個訪問類註解的例子:
Class aClass = TheClass.class; Annotation[] annotations = aClass.getAnnotations(); for(Annotation annotation : annotations){ if(annotation instanceof MyAnnotation){ MyAnnotation myAnnotation = (MyAnnotation) annotation; System.out.println("name: " + myAnnotation.name()); System.out.println("value: " + myAnnotation.value()); } }
你可以像這樣訪問一個給定類的註解:
Class aClass = TheClass.class; Annotation annotation = aClass.getAnnotation(MyAnnotation.class); if(annotation instanceof MyAnnotation){ MyAnnotation myAnnotation = (MyAnnotation) annotation; System.out.println("name: " + myAnnotation.name()); System.out.println("value: " + myAnnotation.value()); }
=====================================================================================
- Method Annotations
下面是一個註解用在方法上的例子:
public class TheClass { @MyAnnotation(name="someName", value = "Hello World") public void doSomething(){} }
你可以像這樣訪問一個方法的註解:
Method method = ... //obtain method object Annotation[] annotations = method.getDeclaredAnnotations(); for(Annotation annotation : annotations){ if(annotation instanceof MyAnnotation){ MyAnnotation myAnnotation = (MyAnnotation) annotation; System.out.println("name: " + myAnnotation.name()); System.out.println("value: " + myAnnotation.value()); } }
你也可以像這樣訪問一個給定方法的註解:
Method method = ... // obtain method object Annotation annotation = method.getAnnotation(MyAnnotation.class); if(annotation instanceof MyAnnotation){ MyAnnotation myAnnotation = (MyAnnotation) annotation; System.out.println("name: " + myAnnotation.name()); System.out.println("value: " + myAnnotation.value()); }
=====================================================================================
- Parameter Annotations
也可以在方法引數的宣告上新增註解。下面是一個例子:
public class TheClass { public static void doSomethingElse( @MyAnnotation(name="aName", value="aValue") String parameter){ } }
你可以像這樣訪問一個Method物件的引數註解:
Method method = ... //obtain method object Annotation[][] parameterAnnotations = method.getParameterAnnotations(); Class[] parameterTypes = method.getParameterTypes(); int i=0; for(Annotation[] annotations : parameterAnnotations){ Class parameterType = parameterTypes[i++]; for(Annotation annotation : annotations){ if(annotation instanceof MyAnnotation){ MyAnnotation myAnnotation = (MyAnnotation) annotation; System.out.println("param: " + parameterType.getName()); System.out.println("name : " + myAnnotation.name()); System.out.println("value: " + myAnnotation.value()); } } }
注意Method.getparameterAnnotations()方法如何返回一個二維的Annotation陣列,該陣列中包含每一個方法的引數註解。
=====================================================================================
- Field Annotations
下面是一個欄位註解的例子:
public class TheClass { @MyAnnotation(name="someName", value = "Hello World") public String myField = null; }
你可以像這樣訪問欄位的註解:
Field field = ... //obtain field object Annotation[] annotations = field.getDeclaredAnnotations(); for(Annotation annotation : annotations){ if(annotation instanceof MyAnnotation){ MyAnnotation myAnnotation = (MyAnnotation) annotation; System.out.println("name: " + myAnnotation.name()); System.out.println("value: " + myAnnotation.value()); } }
你也可以這樣訪問一個給定欄位的註解:
Field field = ... // obtain method object Annotation annotation = field.getAnnotation(MyAnnotation.class); if(annotation instanceof MyAnnotation){ MyAnnotation myAnnotation = (MyAnnotation) annotation; System.out.println("name: " + myAnnotation.name()); System.out.println("value: " + myAnnotation.value()); }
========================================================================================
- 目錄
這是一個本教程到目前為止涵蓋的主題列表:
- Java反射——引言
- Java反射——Class物件
- Java反射——建構函式
- Java反射——欄位
- Java反射——方法
- Java反射——Getter和Setter
- Java反射——私有欄位和私有方法
- Java反射——註解
- Java反射——泛型
- Java反射——陣列
- Java反射——動態代理
- Java反射——類的動態載入和重新載入
(敬請期待下一篇翻譯)