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