1. 程式人生 > >【譯】8. Java反射——註解

【譯】8. Java反射——註解

 =====================================================================================

     使用Java反射機制,在執行時你可以訪問到Java類中所附屬的一些註解。下面是本文所涵蓋的主題列表:

  1. What are Java Annotations? (什麼是Java註解)
  2. Class Annotations (類註解)
  3. Method Annotations (方法註解)
  4. Parameter Annotations (引數註解)
  5. 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());
}

========================================================================================

  •  目錄

  這是一個本教程到目前為止涵蓋的主題列表:     

(敬請期待下一篇翻譯)