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