注解相当于对类,方法,字段等额外的说明,但又不止于此。因为注解内容可以通过反射机制获得。我们可以利用注解+反射机制将一些复杂的操作隐藏起来
注解+反射机制将一些复杂的操作隐藏起来
package cc; import java.lang.annotation.*; @Retention(RetentionPolicy.RUNTIME) // 作用范围 // RetentionPolicy.SOURCE :只在源码级别生效 // RetentionPolicy.CLASS :在编译级别生效,主要是给编译器使用,如overwrite注解 // RetentionPolicy.RUNTIME :在运行时生效,这种方式最常用。用于在运行时改变执行方式,一般通过反射的方式获取注解,并根据注解来决定下一步如何处理 @Target({ElementType.METHOD, ElementType.TYPE}) // 注解用于哪些地方 // ElementType.TYPE :用于类、接口 // ElementType.METHOD :用于方法 // ElementType.CONSTRUCTOR :用于构造函数 // ElementType.FIELD :用于属性 @Inherited // 是否可以被继承 // 假设A是接口,且A上有注解@MyAnnoation。如果B类继承A类,那也会同时继承A类上的注解,但是A类中方法的注解无法被继承。 // 假设A是类, 且A上有注解@MyAnnoation。如果B类继承A类,B无法继承任何注解 @Documented // 是否可以导出java doc public @interface MyAnnoation { // 如果只有一个值,那默认就是value int age(); String value(); }
package cc; /** * Created by fang on 16/9/27. */ @MyAnnoation(value = "class user",age=10) public class User { @MyAnnoation(value = "method1", age=11) public void show(){ System.out.println("method1"); } @MyAnnoation(value = "method2", age=12) public void show1(){ System.out.println("method2"); } }
public static void main(String[] args) throws InvocationTargetException, IllegalAccessException { for(Method m:User.class.getMethods()){ for(Annotation annotation:m.getAnnotations()){ String annotationName = annotation.annotationType().getName(); if(annotationName.equals("cc.MyAnnoation")){ System.out.print("age: " + ((MyAnnoation) annotation).age()); System.out.print(", value: "+((MyAnnoation) annotation).value()); System.out.print(", MyAnnoation: "); m.invoke(new User()); } } } System.out.println(User.class.getAnnotation(MyAnnoation.class).value()); }