java 自定义注解的实例详解

时间:2021-09-15 21:46:47

java  自定义注解的实例详解

Java的Annotation是在5.0版本之后引入的,可以用于创建文档,跟踪代码中的依赖性,并且可以执行编译时期检查。注解就是给虚拟机看的,代表程序的一些特殊的功能。JDK中提供了@Override,@SuppressWarning,@Deprecated三种注解,当让还有元注解,@Target,@Retention,@Documented,@Inherited,元注解的作用负责注解其它注解。

    要想了解注解,就要了解自定义注解,了解是通过反射来实现的。

    首先,我们先自定义一个注解,

?
1
2
3
4
@Retention(value=RetentionPolicy.RUNTIME)
public @interface MyTest {
 
}

   接着再写一个测试demo

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public class AnnotationDemo1 {
  @MyTest
  public void demo1(){
    System.out.println("方法1...");
  }
   
  @MyTest
  public void demo2(){
    System.out.println("方法2...");
  }
  @Test
  public void demo3(){
    System.out.println("方法3...");
  }

   最后要让AnnotationDemo1中所有带Mytest注解的方法运行,接下来是运行类

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public class DemoRunner {
public static void main(String[] args) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException, InstantiationException { 
    //获得测试类的class
    Class clazz=AnnotationDemo1.class;
    //获得class中的所有的方法
    Method[] mothods=clazz.getMethods();
    //遍历每个方法,
    for(Method method:mothods){
      boolean flag = method.isAnnotationPresent(MyTest.class);
       System.out.println(flag);
      if(flag){
        // 说明方法上有MyTest注解:
        method.invoke(clazz.newInstance(), null);
      }
    }
  }
}

  最后测试就能输出方法1...和方法2了...,这样也就简单实现自定义注解了。

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

原文链接:http://blog.csdn.net/kdc18333608478/article/details/52503500