`
chenzhou123520
  • 浏览: 4250081 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

自定义Annotation

    博客分类:
  • Java
阅读更多

 

定义简单的Annotation

 

Annotation的定义格式:

 

[public] @interface Annotation名称{
	数据类型 变量名称();
}

 定义一个简单的Annotation

 

public @interface MyDefaultAnnotationNoneParam {
}

 之后就可以直接在程序中使用”@Annotation名称的格式。

 

@MyDefaultAnnotationNoneParam
public class AnnotationTest {
}

 

此时就表示在AnnotationTest类上使用Annotation

还可以在Annotation中设置,使用变量接收参数

 

public @interface MyDefaultAnnotationSingleParam {
	public String value();	//接收设置的内容
}

 

在使用的时候就必需清楚地指明变量的内容

 

@MyDefaultAnnotationSingleParam("陈洲")
public class AnnotationTest {
}

或者也可以使用明确的标记,表示内容赋给哪个参数

 

@MyDefaultAnnotationSingleParam(value="陈洲")
public class AnnotationTest {
}

 

也可以同时设置多个参数

 

public @interface MyDefaultAnnotationMoreParam {
	public String key();
	public String value();
}

 

Annotation在使用的时候需要设置两个参数,一个是key,另外一个是value

 

@MyDefaultAnnotationMoreParam(key="name",value="陈洲")
public class AnnotationTest {
}

也可以使用数组当做Annotation的属性

 

public @interface MyDefaultAnnotationArrayParam {
	public String[] value();
}

 接收的内容本身是一个数组类型,所以要传递数组参数

 

@MyDefaultAnnotationArrayParam(value={"China","America"})
public class AnnotationTest {
} 

 

以上所定义的全部Annotation有一个特点,所有的参数内容需要在使用注释时设置上去,那么也可以为一个参数设置默认的内容,在声明的时候使用default即可。

public @interface MyDefaultAnnotationValue {
	public String key() default "name";		//指定好了默认值
	public String value() default "chenzhou";	//指定好了默认值
} 

 

当再去使用此Annotation时就不用设置值了

 

@MyDefaultAnnotationValue
public class AnnotationTest {
} 

没有设置内容,编译也不会出现任何错误。

 

在操作中,对于一个Annotation而言有时候会固定其取值范围,只能取固定的几个值,那么这个时候实际上就需要依靠枚举。

public enum Names {
	CHENZHOU,GONGYONG,YIXIN,
} 

以后的Annotation取值,只能从这三个值中取走。  

 

public @interface MyDefaultAnnotationEnum {
	public MyName name() default MyName.CHENZHOU;//指定默认值
}

 

 

 

 

此时以上的Annotation已经设置好了一个枚举中的内容作为默认值,那么外部使用此Annotation的时候也需要从枚举固定取值

 

@MyDefaultAnnotationEnum(name=MyName.CHENZHOU)
public class AnnotationTest {
}

 

 

 

RetentionRetentionPolicy

 

Annotation,可以使用Retention定义一个Annotation的保存范围,此Annotation的定义如下:

 

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Retention {
    RetentionPolicy value();
} 

 

在以上的Retention定义中存在一个RetentionPolicy类型的变量,此变量用于指定Annotation的保存范围,RetentionPolicy包含三种范围

RetentionPolicy的三种范围

 

No.

范围

描述

1

SOURCE

Annotation类型的信息只会保存在程序源文件中(*.java),编译之后不会保存在编译好的类文件(*.class)之中

2

CLASS

Annotation类型的信息会保存在程序源文件(*.java)和编译好的类文件(*.class)之中,在使用此类的时候,这些Annotation的信息将不会被加载到虚拟机JVM之中,如果一个Annotation声明时没有指定范围,则默认是此范围

3

RUNTIME

Annotation类型的信息会保存在程序源文件(*.java)和编译好的类文件(*.class)之中,在执行时也会加载到JVM

 

 

 在三种范围中,最需要关心的就是RUNTIME范围,因为在执行的时候起作用。

使用Retention指定一个Annotation的范围,范围为RUNTIME

 

@Retention(value = RetentionPolicy.RUNTIME)	//表示此Annotation在运行时有效
public @interface MyDefaultRetentionAnnotation {
	public String name() default "chenzhou";
}

 Annotation可以在运行时起作用

 

内建AnnotationRetentionPolicy

 

  • Override定义采用的是@Retention(value=SOURCE),只能在源文件中出现
  • Deprecated定义采用的是@Retention(value=RUNTIME),可以在执行时出现。
  • SuppressWarnings定义采用的是@Retention(value= SOURCE),只能在源文件中出现

Documented 标记 
这个annotation非常简单,也非常容易理解,使用过javadoc命令的人都会很清楚,我们可以用javadoc命令将方法,类,变量等前面的注释转换成文档,在默认的情况下javadoc命令不会将我们的annotation生成再doc中去的,所以使用该标记就是告诉jdk让它也将annotation生成到doc中去,比如

@Documented
public @interface Retention {
    RetentionPolicy value();
} 
 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics