一、自定义注解
元注解:
@interface注解: 定义注解接口
@Target注解: 用于约束被描述的注解的使用范围,当被描述的注解超出使用范围则编译失败。如:ElementType.METHOD,ElementType.TYPE;
@Retention 注解:用于约束被定义注解的作用范围,作用范围有三个:
1、RetentionPolicy.SOURCE:作用范围是源码,作用于Java文件中,当执行javac时去除该注解。
2、RetentionPolicy.CLASS:作用范围是二进制码,就是存在于class文件中,当执行Java时去除该注解。
3、RetentionPolicy.RUNTIME:作用范围为运行时,就是我们可以通过动态获取该注释。
@Documented:用于指定javadoc生成API文档时显示该注释。
@Inherited:用于指定被描述的注释可以被其描述的类的子类继承,默认情况是不能被其子类继承。
自定义注解接口:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
package com.java.annotation; import java.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.lang.annotation.Inherited; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; @Target({ElementType.METHOD,ElementType.TYPE}) @Inherited @Documented @Retention(RetentionPolicy.RUNTIME) public @interface Annotation_my { String name() default "张三";//defalt 表示默认值 String say() default "hello world"; int age() default 21; } |
接下来我们定义一个接口:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
package com.java.annotation; @Annotation_my //使用我们刚才定义的注解 public interface Person { @Annotation_my public void name(); @Annotation_my public void say(); @Annotation_my public void age(); } |
接口定义好了,我们就可以写接口的实现类了(接口不能实例化)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
package com.java.annotation; @Annotation_my @SuppressWarnings("unused") public class Student implements Person { private String name; @Override @Annotation_my(name="流氓公子") //赋值给name 默认的为张三 //在定义注解时没有给定默认值时,在此处必须name赋初值 public void name() { } @Override @Annotation_my(say=" hello world !") public void say() { } @Override @Annotation_my(age=20) public void age() { } } |
然后我们就编写一个测试类测试我们的注解
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
package com.java.annotation; import java.lang.annotation.Annotation; import java.lang.reflect.Field; import java.lang.reflect.Method; public class Text { Annotation[] annotation = null; public static void main(String[] args) throws ClassNotFoundException { new Text().getAnnotation(); } public void getAnnotation() throws ClassNotFoundException{ Class<?> stu = Class.forName("com.java.annotation.Student");//静态加载类 boolean isEmpty = stu.isAnnotationPresent(com.java.annotation.Annotation_my.class);//判断stu是不是使用了我们刚才定义的注解接口if(isEmpty){ annotation = stu.getAnnotations();//获取注解接口中的 for(Annotation a:annotation){ Annotation_my my = (Annotation_my)a;//强制转换成Annotation_my类型 System.out.println(stu+":\n"+my.name()+" say: "+my.say()+" my age: "+my.age()); } } Method[] method = stu.getMethods();// System.out.println("Method"); for(Method m:method){ boolean ismEmpty = m.isAnnotationPresent(com.java.annotation.Annotation_my.class); if(ismEmpty){ Annotation[] aa = m.getAnnotations(); for(Annotation a:aa){ Annotation_my an = (Annotation_my)a; System.out.println(m+":\n"+an.name()+" say: "+an.say()+" my age: "+an.age()); } } } //get Fields by force System.out.println("get Fileds by force !"); Field[] field = stu.getDeclaredFields(); for(Field f:field){ f.setAccessible(true); System.out.println(f.getName()); } System.out.println("get methods in interfaces !"); Class<?> interfaces[] = stu.getInterfaces(); for(Class<?> c:interfaces){ Method[] imethod = c.getMethods(); for(Method m:imethod){ System.out.println(m.getName()); } } } } |
以上这篇Java 自定义注解及利用反射读取注解的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/lzh984294471/p/4959953.html