@(Java)[Annotation|Java]

Java Annotation概述

用途

  • 编译器的相关信息,如用于检测错误和一些警告
  • 编译时和部署时的处理,如一些软件用于自动生成代码之类的
  • 运行时处理

自定义注解

和接口的定义类似,只是用@interface来标识,注解中包含的属性可以具有默认值,如下:

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface ActivityMetadata {
String activityName() default "活动";
}

预定义注解

用于Java语言中的注解

  • @Deprecated:用于表示一些类,方法或者属性不再使用
  • @Override:用于指示编译器,表示元素覆盖了定义在父类的元素
  • @SuppressWarnings:用于指示编译器不再产生警告
  • @SafeVarargs:用于方法或者构造器,表示没有对其参数有不安全的操作,编译器不再产生未检查警告
  • @FunctionalInterface:Java 8中引入,定义类型为函数接口

用于其它注解的注解(元注解)

@Retention

表示注解如何存储,也可以视作注解的生命周期

RetentionPolicy.SOURCE仅仅保留在源代码中,编译器忽略该注解
RetentionPolicy.CLASS可以用在在编译器在编译期间,但是JVM忽略该注解
RetentionPolicy.RUNTIME保留到JVM中,可以在运行期中使用

:大部分框架自定义的注解一般用于RUNTIME,在运行期应用。

@Documented

表示在使用javadoc生成文档的时候,也需要将该注解包含进去

@Target

用于限制其它注解所能使用的范围

ElementType.ANNOTATION_TYPE注解
ElementType.CONSTRUCTOR构造器
ElementType.FIELD属性
ElementType.LOCAL_VARIABLE局部变量
ElementType.METHOD方法
ElementType.PACKAGE包定义
ElementType.PARAMETER方法参数
ElementType.TYPE任意类型

@Inherited

表示注解可以被继承,默认不继承

@Repeatable

Java 8 中引入,指示注解可以被重复应用于同一个元素

示例:

功能说明:定义一个注解,该注解用于反应属性的中文说明,程序使用反射从中解析出该类的属性以及对应的中文说明。

Activity.java

public class Activity {

	@ActivityMeta(description="活动名称")
private String activityName; @ActivityMeta(description="活动类型")
private String activityType; public String getActivityName() {
return activityName;
} public void setActivityName(String activityName) {
this.activityName = activityName;
} public String getActivityType() {
return activityType;
} public void setActivityType(String activityType) {
this.activityType = activityType;
}
}

ActivityMeta.java

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface ActivityMeta {
public String description();
}

Demo

public class AnnotationDemo {

	private static final Logger logger = LoggerFactory
.getLogger(AnnotationDemo.class); @Test
public void demo() { for (Field field : Activity.class.getDeclaredFields()) {
ActivityMeta activityMeta = field.getAnnotation(ActivityMeta.class);
logger.debug(field.getName()+":" + activityMeta.description());
}
}
}

输出:

2016-07-16 12:12:41 [DEBUG]-[Thread: main]-[com.jabnih.analysis.annotation.AnnotationDemo.demo()]:
activityName:活动名称 2016-07-16 12:12:41 [DEBUG]-[Thread: main]-[com.jabnih.analysis.annotation.AnnotationDemo.demo()]:
activityType:活动类型

参考:

官方Tutorial:

https://docs.oracle.com/javase/tutorial/java/annotations/index.html

04-30 04:03