什么是注解

注解是 Java 5 的一个新特性。注解是插入你代码中的一种注释或者说是一种元数据(meta data)。这些注解信息可以在编译期使用预编译工具进行处理(pre-compiler tools),也可以在运行期使用 Java 反射机制进行处理。

  1. @MyAnnotation(name="someName", value = "Hello World")
  2. public class TheClass {
  3. }

在 TheClass 类定义的上面有一个 @MyAnnotation 的注解。注解的定义与接口的定义相似,下面是 MyAnnotation 注解的定义:

  1. @Retention(RetentionPolicy.RUNTIME)
  2. @Target(ElementType.TYPE)
  3. public @interface MyAnnotation {
  4. public String name();
  5. public String value();
  6. }

在 interface 前面的 @ 符号表明这是一个注解,一旦你定义了一个注解之后你就可以将其应用到你的代码中,就像之前我们的那个例子那样。
@Retention(RetentionPolicy.RUNTIME)@Target(ElementType.TYPE),说明了这个注解该如何使用。
@Retention(RetentionPolicy.RUNTIME) 表示这个注解可以在运行期通过反射访问。如果你没有在注解定义的时候使用这个指示那么这个注解的信息不会保留到运行期,这样反射就无法获取它的信息。
@Target(ElementType.TYPE) 表示这个注解只能用在类型上面(比如类跟接口)。你同样可以把 Type 改为 Field 或者 Method,或者你可以不用这个指示,这样的话你的注解在类,方法和变量上就都可以使用了。

类注解

  1. Class aClass = TheClass.class;
  2. Annotation[] annotations = aClass.getAnnotations();
  3. for(Annotation annotation : annotations){
  4. if(annotation instanceof MyAnnotation){
  5. MyAnnotation myAnnotation = (MyAnnotation) annotation;
  6. System.out.println("name: " + myAnnotation.name());
  7. System.out.println("value: " + myAnnotation.value());
  8. }
  9. }

还可以像下面这样指定访问一个类的注解

  1. Class aClass = TheClass.class;
  2. Annotation annotation = aClass.getAnnotation(MyAnnotation.class);
  3. if(annotation instanceof MyAnnotation){
  4. MyAnnotation myAnnotation = (MyAnnotation) annotation;
  5. System.out.println("name: " + myAnnotation.name());
  6. System.out.println("value: " + myAnnotation.value());
  7. }

方法注解

  1. public class TheClass {
  2. @MyAnnotation(name="someName", value = "Hello World")
  3. public void doSomething(){}
  4. }

可以像这样访问方法注解

  1. Method method = ... //获取方法对象
  2. Annotation[] annotations = method.getDeclaredAnnotations();
  3. for(Annotation annotation : annotations){
  4. if(annotation instanceof MyAnnotation){
  5. MyAnnotation myAnnotation = (MyAnnotation) annotation;
  6. System.out.println("name: " + myAnnotation.name());
  7. System.out.println("value: " + myAnnotation.value());
  8. }
  9. }

可以像这样访问指定的方法注解

  1. Method method = ... // 获取方法对象
  2. Annotation annotation = method.getAnnotation(MyAnnotation.class);
  3. if(annotation instanceof MyAnnotation){
  4. MyAnnotation myAnnotation = (MyAnnotation) annotation;
  5. System.out.println("name: " + myAnnotation.name());
  6. System.out.println("value: " + myAnnotation.value());
  7. }

参数注解

  1. public class TheClass {
  2. public static void doSomethingElse(
  3. @MyAnnotation(name="aName", value="aValue") String parameter){
  4. }
  5. }

可以通过 Method 对象来访问方法参数注解

  1. Method method = ... //获取方法对象
  2. Annotation[][] parameterAnnotations = method.getParameterAnnotations();
  3. Class[] parameterTypes = method.getParameterTypes();
  4. int i=0;
  5. for ( Annotation[] annotations : parameterAnnotations ) {
  6. Class parameterType = parameterTypes[i++];
  7. for ( Annotation annotation : annotations ) {
  8. if ( annotation instanceof MyAnnotation ) {
  9. MyAnnotation myAnnotation = (MyAnnotation) annotation;
  10. System.out.println("param: " + parameterType.getName());
  11. System.out.println("name : " + myAnnotation.name());
  12. System.out.println("value: " + myAnnotation.value());
  13. }
  14. }
  15. }

变量注解

  1. public class TheClass {
  2. @MyAnnotation(name="someName", value = "Hello World")
  3. public String myField = null;
  4. }

可以像这样来访问变量的注解:

  1. Field field = ... //获取方法对象
  2. Annotation[] annotations = field.getDeclaredAnnotations();
  3. for(Annotation annotation : annotations){
  4. if(annotation instanceof MyAnnotation){
  5. MyAnnotation myAnnotation = (MyAnnotation) annotation;
  6. System.out.println("name: " + myAnnotation.name());
  7. System.out.println("value: " + myAnnotation.value());
  8. }
  9. }

可以像这样访问指定的变量注解

  1. Field field = ...//获取方法对象
  2. Annotation annotation = field.getAnnotation(MyAnnotation.class);
  3. if ( annotation instanceof MyAnnotation ) {
  4. MyAnnotation myAnnotation = (MyAnnotation) annotation;
  5. System.out.println("name: " + myAnnotation.name());
  6. System.out.println("value: " + myAnnotation.value());
  7. }