我们用过JDK给我们提供的 @Override @Deprecated @SuppressWarning 注解 ,这些注解是JDK给我们提供的,我们只是在用别人写好的东西,那么我们是否可以自己写注解呢?当然是可以的。
我们写的注解包括三个环节:
1、 注解的声明,也就是注解类的定义。
形式如下 @interface 来进行注解的声明。
package me.test;
import java.lang.annotation.* ;//导入注解包中所有注解
@Retention(RetentionPolicy.RUNTIME) //解释如下
@Target(ElementType.TYPE)//解释如下
public @interface MyAnnotation
{
}
@Retention(RetentionPolicy.RUNTIME)
指定了注解保留的周期,注解的生命周期有是三个,RetentionPolicy 枚举的三个值代表了三个声明周期,默认是CLASS。
枚举常量摘要CLASS
编译器将把注释记录在类文件中,但在运行时 VM 不需要保留注释。RUNTIME
编译器将把注释记录在类文件中,在运行时 VM 将保留注释,因此可以反射性地读取。SOURCE
编译器要丢弃的注释。
@Target(ElementType.TYPE)
这个标识注解应该标在那里ElementType的几个枚举值就代表了,注解应该写在的位置。
CONSTRUCTOR
构造方法声明FIELD
字段声明(包括枚举常量)LOCAL_VARIABLE
局部变量声明METHOD
方法声明PACKAGE
包声明PARAMETER
参数声明TYPE
类、接口(包括注释类型)或枚举声明
2、 使用了注解的类或者方法。
@MyAnnotation
class A
{
}
3、 利用反射来操作注解,详细见代码。
Class类有一个方法:
<A extends Annotation>
A getAnnotation(Class<A> annotationClass)
这个方法接受一个注解的字节码参数 ,然后返回这个类所标识的注解对象 ,因为我们标识了一个注解就相当于产生了一个注解对象 。
booleanisAnnotationPresent(Class<? extends Annotation> annotationClass)
这个方法判断一个类是否被注解所标识。
下面是代码示例:
MyAnnotationTest.java中
package me.test;
import java.lang.annotation.Annotation;
@MyAnnotation
public class MyAnnotationTest
{
public static void main(String []args)
{
if(MyAnnotationTest.class.isAnnotationPresent( MyAnnotation.class))
{
MyAnnotation an=(MyAnnotation)MyAnnotationTest.class.getAnnotation(MyAnnotation.class) ;
System.out.println(an.toString());
}
}
}
MyAnnotation.java中
package me.test;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
public @interface MyAnnotation
{
}