把注解类看成特殊的类
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
public @interface Description {
public String value();
}
这个类特殊在哪里:
1. 声明用@interface
2. 类中的方法实际上是个字段(可以这么看),因为如此,这些方法都不能有参数
3. 这些字段的类型只能是“四类八种”+类+枚举+它们的数组
4. 可以给字段赋默认值,使用default关键字
Name.java描述类中的方法
Csdn.java写一个类用来测试自定义的annotation
运行的结果:
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
public @interface Description {
public String value();
}
这个类特殊在哪里:
1. 声明用@interface
2. 类中的方法实际上是个字段(可以这么看),因为如此,这些方法都不能有参数
3. 这些字段的类型只能是“四类八种”+类+枚举+它们的数组
4. 可以给字段赋默认值,使用default关键字
5. 可以通过反射拿到类的注解和它们的值
package com.chen.annotation;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Documented
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface Author {
AuthorName name() default AuthorName.chen;
}
注解类(Author)一般用三个注解来说明该注解的一些属性
1. @Document 说明使用该annotation修饰的类在生成javadoc文档时,是否显示该注解,不写@Document就忽略该annotation
2. @Target 说明该annotation可以修饰哪些类型,这里的Type是可以修饰类,枚举等,另外还有类的方法,构造方法,字段等
3. @Retention 说明该annotation的保留策略,有三种值,SOURCE,CLASS,RUNTIME,分别是该annotation只保留在源代码中,源代码+class文件中,源代码+class文件中+运行时加载到jvm中
Author这个注解用来说明一个类的作者是谁,这里的Author注解是一个枚举类型,并且默认值是AuthorName.chen,下面给出AuthorName这个枚举类。
AuthorName.java
package com.chen.annotation;
public enum AuthorName {
zhangsan,chen,xiaoyue
}
Description.java(用来描述一个类)
package com.chen.annotation;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
public @interface Description {
public String value();
}
Name.java描述类中的方法
package com.chen.annotation;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Documented
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Name {
public String origin();
public String community() default "python";
}
Csdn.java写一个类用来测试自定义的annotation
package com.chen.annotation;
@Description(value = "this is good community for programmer!")
@Author
public class Csdn {
@Name(origin = "chen", community = "java")
public String getName1() {
return null;
}
@Name(origin = "jinpeng")
public String getName2() {
return null;
}
}
Test.java通过反射获得注解的信息
package com.chen.annotation;
import java.lang.reflect.Method;
public class Test {
public static void main(String[] args) {
Class<Csdn> clazz = Csdn.class;
Method[] methods = clazz.getDeclaredMethods();
if (clazz.isAnnotationPresent(Description.class)) {
Description description = clazz.getAnnotation(Description.class);
System.out.println(description.value());
}
if (clazz.isAnnotationPresent(Author.class)) {
Author author=clazz.getAnnotation(Author.class);
System.out.println(author.name());
}
for (int i = 0; i < methods.length; i++) {
if (methods[i].isAnnotationPresent(Name.class)) {
Name name = methods[i].getAnnotation(Name.class);
System.out.println(name.origin() + ":" + name.community());
}
}
}
}
运行的结果:
this is good community for programmer!
chen
chen:java
jinpeng:python