Java注解在1.5版本的时候推出,很多优秀的框架都支持注解模式的配置,比如 Spring 等。本文介绍注解相关的定义,以及自定义注解的方法。
注解的基本概念注解(Annotation)提供了一种关联信息以及元数据的途径和方法。是一个接口,程序可以通过反射来获取指定程序元素中的 Annotation 对象,然后通过解析 Annotation 对象获取注解中的元数据。可以应用于包、类型、构造方法、方法、成员变量、参数、局部变量等等的声明中。在注解中以"name = value"的形式存储。
Annotation 不能影响程序代码的执行,尽管一些注解通过反射技术可以在运行时被访问,但是java的语言解释器在工作时是忽略他们的。
注解的分类:
@annotation(value)
的形式,省略 name,其中 value 就是注解value元素对应的值。所谓元注解即是注解的注解,用来负责对其他注解进行注解。
Java5提供了4个标准的元注解(meta-annotation)类型:
@Target
- CONSTRUCTOR: 描述构造器
- FIELD: 描述域属性
- LOCAL_VARIABLE: 描述局部变量
- METHOD: 描述方法
- PACKAGE: 描述包
- PARAMETER: 描述参数
- TYPE: 描述类、接口或注解、枚举类型 enum
@Retention
- SOURCE: 源文件保留,被编译器所丢弃
- CLASS: 在字节码文件(*.class)中保留,被JVM所丢弃
- RUNTIME: 在运行时保留
@Inherited
使用 @interface 自定义注解的时,继承 java.lang.annotation.Annotation 接口。被定义的注解不能再继承其他的注解或接口。注解中的每一个方法实际上相当于声明配置参数。其中方法的名称就是参数的名称,方法不能有任何的参数和 throws 语句,方法的返回值就是参数的类型(返回值类型只能是基本数据类型、Class、String、enum、Annotation),同时可以使用default关键字来声明参数的默认值。
注解的参数设置:
示例:
/**
* 自定义注解示例代码
*
* @author Michal
* @create 2016-04-19 15:39
*/
@Target({ ElementType.METHOD, ElementType.TYPE })
@Retention(RetentionPolicy.RUNTIME)
public @interface Table {
/**
* 数据库表名
*/
String value();
}
/**
* 自定义注解示例代码
*
* @author Michal
* @create 2016-04-19 15:42
*/
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Column {
/**
* 数据库的列名
*
* @return
*/
String column() default "";
/**
* 数据类型
*
* @return
*/
String type() default "";
/**
* 数据大小
*
* @return
*/
int length() default 0;
}
注解解析器
注解并不会影响代码的运行,因此必须配合解析器使用,否则注解和注释也没什么具体的区别了。使用Java反射API中的 AnnotatedElement 接口可以方便进行注解的解析。
/**
* 注解解析器
*
* @author Michal
* @create 2016-04-19 15:58
*/
public class AnnotationUtil {
public static void parse(Class<?> target) {
Table table = target.getAnnotation(Table.class);
System.out.println("数据库表名: " + table.value());
Field[] fields = target.getDeclaredFields();
for (Field f : fields) {
Column column = f.getAnnotation(Column.class);
System.out.println("列名: " + column.column() + ", 数据类型: " + column.type() + ", 数据大小: " + column.length());
}
}
}
/**
* @author Michal
* @create 2016-04-19 16:15
*/
public class Main {
public static void main(String[] args) {
AnnotationUtil.parse(TableTest.class);
}
}
@Table("测试表")
class TableTest {
@Column(column = "名字", type = "java.lang.String", length = 12)
private String name;
@Column(column = "年龄", type = "int", length = 12)
private int age;
@Column(column = "地址", type = "String")
private String address;
}
运行结果:
数据库表名: 测试表
列名: 名字, 数据类型: java.lang.String, 数据大小: 12
列名: 年龄, 数据类型: int, 数据大小: 12
列名: 地址, 数据类型: String, 数据大小: 0
2025 - 快车库 - 我的知识库 重庆启连科技有限公司 渝ICP备16002641号-10
企客连连 表单助手 企服开发 榜单123