`

Annotaion

 
阅读更多

Annotation 是一种注释,可以标注在类、方法、属性上,对其在另一个层面(一般在系统实现上)进行说明。

 

 

Annotation 的定义类似于接口:

 

@Retention(RetentionPolicy.RUNTIME)//指明该Annotation 在运行时存在,可通过对类反射获取标注的Annotation信息

 

@Target( [

               ElementType.METHOD //可以标注在方法上

               |ElementType.TYPE //可以标注在类上

               |ElementType.FIELD //可以标注在属性上

               |ElementType.CONSTRUCTOR //可以标注在构建器上

               |ElementType.PARAMETER////可以标注在方法参数上

       ]

)

 

[@Inherited ] //该注释的类的子类,自动具有该注释(相当于子类上写了该注释)

[public] @interface 注释名{

    [类型 注释项名称A() [default 默认值];]

    [类型 注释项名称B() [default 默认值];]

    [类型 注释项名称C() [default 默认值];]

   .....

}

 

 

 

举例:  

定义一个实体类的注释,说明其对应数据库表的信息:

/**
 * 表定义
 */
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)

public @interface Table {
String tableName();//表名
String createTableSql() default "";//建表脚本
String pkFiled() default ""; //主键属性
String pkCreateType() default "";//主键生成类型
}

 

 

 

/**
 * 数据库表中的列定义
 */
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface Column {
	String columnName();//列名
	String columnType();//列类型 可以再定义一下enum,表示它的可选值
}

 

 Annotation 应用:

   Annotation 对类进行注释:

@Table(tableName="person")
public class Person {
	@Column(columnName="person_name",columnType="varchar2")
	String name;

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	@Override
	public String toString() {
		return "Person [name=" + name + "]";
	}
	
}

Annotation标注时写法:

  @注释名(注释项A=注释值,注释项B=注释值,注释项C=注释值.....)

 当一个Annotation只有一个value注释项时,标注时可以省略注释项:

  @注释名(注释值)

 

 

 

运行时获取类的注释信息:

   

 

import java.beans.BeanInfo;
import java.beans.Introspector;
import java.beans.PropertyDescriptor;
import java.lang.annotation.Annotation;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.Arrays;
import java.util.List;


public class AnnotationUtils {
	/**
	 * 获取类上的指定Annotation
	 */
	 public <T extends Annotation> T getClassAnnotation(Class<?> classz,Class<T> annotationClass){
		 if(classz.isAnnotationPresent(annotationClass)){
			 return classz.getAnnotation(annotationClass);
		 }else{
			 return null;
		 }
	 }
	    /**
		 * 获取类属性上的指定Annotation
		 */
	 public  <T extends Annotation> T getFieldAnnotation(Field  field,Class<T> annotationClass){
		 if(field.isAnnotationPresent(annotationClass)){
			 return field.getAnnotation(annotationClass);
		 }else{
			 return null;
		 }
	 }
	    /**
		 * 获取类方法上的指定Annotation
		 */
	 public <T extends Annotation> T getMethodAnnotation(Method method,Class<T> annotationClass){
		 if(method.isAnnotationPresent(annotationClass)){
			 return method.getAnnotation(annotationClass);
		 }else{
			 return null;
		 }
	 }
	    /**
		 * 获取类上的所有Annotation
		 */
	 public   List<Annotation> getClassAllAnnotation(Class<?> classz ){
		 List<Annotation> list = null;
		 Annotation annotations[] =  classz.getAnnotations();
		 if(annotations != null){
		  list = Arrays.asList(annotations);
		 }
		 return list;
	 }
	   /**
		 * 获取类属性上的所有Annotation
		 */
	 public   List<Annotation> getFieldAllAnnotation(Field field ){
		 List<Annotation> list = null;
		 Annotation annotations[] =  field.getAnnotations();
		 if(annotations != null){
		  list = Arrays.asList(annotations);
		 }
		 return list;
	 }
	 /**
		 * 获取类方法上的所有Annotation
		 */
	 public   List<Annotation> getMethodAllAnnotation(Method method ){
		 List<Annotation> list = null;
		 Annotation annotations[] =  method.getAnnotations();
		 if(annotations != null){
		  list = Arrays.asList(annotations);
		 }
		 return list;
	 }
	 public static void main(String args []){
		 try{
			 AnnotationUtils annoUtils  = new AnnotationUtils();
			 Table table = annoUtils.getClassAnnotation(Person.class, Table.class);
			 if(table != null){
				 System.out.println("Person class -->[tableName="+table.tableName()+"]");//输出:Person class -->[tableName=person]
			 }
			 Column column =  annoUtils.getFieldAnnotation(Person.class.getDeclaredField("name"),Column.class);
			 if(column != null){
				 System.out.println("Person.name -->[column name="+column.columnName()+" ,column type="+column.columnType()+"]");//输出:Person.name -->[column name=person_name ,column type=varchar2]
			 }
			 
		 }catch(Exception e){
			 e.printStackTrace();
		 }
	 }
}

 自定义注释的父类是:Annotation

  

 Annotation类型的判断(源自struts2源码):

Inject findInject( Annotation[] annotations ) {
		for ( Annotation annotation : annotations ) {
			if (annotation.annotationType() == Inject.class) {
				return Inject.class.cast(annotation);
			}
		}
		return null;
	}

 

分享到:
评论

相关推荐

    spring+hibernate annotaion

    在本项目中,"spring+hibernate annotaion"指的是利用注解(Annotation)的方式整合Spring和Hibernate,实现一个全注解的应用。这种方式可以简化配置,提高开发效率,并且使得代码更加简洁易读。 Spring框架是Java...

    annotaion-hibernate

    【标题】:“annotaion-hibernate” 涉及的关键技术是Hibernate注解,这是一个针对初学者的教程,旨在深入讲解如何在Java应用程序中使用Hibernate框架的注解进行对象关系映射(ORM)。 【描述】:Hibernate注解是...

    hibernate annotaion api 中文与英文版

    Hibernate是一个流行的Java持久化框架,它允许开发者将对象模型映射到关系数据库,极大地简化了数据库操作。在Hibernate中,注解(Annotation)API是一种声明式的方法,用于定义对象-关系映射(ORM)。...

    smartTrinity_script_9_trinity_fa_annotaion_GPL2.0_20230324.zip

    《smartTrinity_script_9_trinity_fa_annotaion_GPL2.0_20230324.zip:深度解析与应用》 在生物信息学领域,`smartTrinity`是一个常用的工具,用于组装RNA-seq数据,构建转录本草图,特别是对于非模式生物或低覆盖...

    swagger-api-annotaion_inputFiles.lst_swagger-ui自定义注解api_swagger_

    在这个名为"swagger-api-annotaion_inputFiles.lst_swagger-ui自定义注解api_swagger_"的资源中,我们将探讨如何使用Swagger的注解来增强Spring Boot应用中的API文档,并自定义Swagger UI以适应特定项目需求。...

    练习annotaion

    "练习annotaion"这个标题暗示我们将探讨注解的使用和实践。尽管描述简单,仅提到这是一个例子,但我们可以深入探讨注解的基本概念、类型以及它们在Java等编程语言中的应用。 注解在Java中被广泛使用,它们提供了一...

    Spring Annotaion Support详细介绍及简单实例

    Spring框架作为Java领域内最为流行的企业级应用开发框架,其核心特点之一便是对依赖注入和面向切面编程(AOP)的优秀支持。Spring通过一系列的扩展点和钩子(hook),允许开发者自定义容器行为,其中...

    Spring3.0中annotaion的运用

    在Spring 3.0版本中,注解(Annotation)的应用极大地简化了框架的配置和代码的编写,使得Java开发者能够更加优雅地实现依赖注入、AOP(面向切面编程)等核心功能。本文将深入探讨Spring 3.0中注解的运用,包括其重要...

    java Annotaion实现菜单和工具栏国际化

    这是利用java Annotation实现的菜单和工具栏国际化的实例,是《java学习脚印: 反射与注释(Annotation)》一文中综合实例的例子。博客参见:http://blog.csdn.net/wangdingqiaoit/article/details/20130539

    abhc:“ABHC”指Annotaion Binding Http Cilent。 这是和俊英一起学习的

    ABHC,全称为"Annotaion Binding Http Client",是一个基于Java编程语言的HTTP客户端库。这个库的主要目的是简化HTTP请求的处理,通过注解的方式来绑定请求参数和响应数据,从而提供更加直观和便捷的API使用体验。在...

    struts2 annotaion

    Struts2 Annotation是Struts2框架的一个特性,它允许开发者使用Java注解的方式来替代XML配置文件,简化Action类与URL的映射关系。这个特性主要由`struts2-convention-plugin`插件提供支持,因此在使用前需要将对应的...

    javax.annotation-api-1.3.2

    JDK9及以上版本没有javax.annotation-api-***.jar包 ,无法使用注解:@Resource JDK新特性,高版本JDK没有自带的javax(java扩展包)了。或者是使用的JDK不完整。 下载javax.annotation.jar包,导入到lib文件夹下,...

    java for hibernate

    6. **注解驱动(Annotation Driven)**:在`hib_009_annotaion`和`hib_009_annotaion2`中,我们看到使用注解代替XML配置文件来描述对象和数据库之间的映射。这种方式更简洁且易于维护。 7. **事务管理**:Hibernate...

    流程管理系统,rbac,dwr

    该项目使用了JBPM4,并对JBPM4进行预研,掌握JBPM4的使用,主要是JPDL和JBPM4常用API,并完成Extjs3+Struts2+Spring+Hibernate+JBPM4+Annotaion框架的搭建和规划,并对故障单部分进行设计和编码,应用工作流JBPM4...

    Pafa4新特性指南1.0.1苏秩

    - **Import配置文件**和**支持Annotaion**:与App层类似,优化配置并利用注解简化配置和编码。 - **APP调用新方式**:提供新的API或方法进行Web层的调用。 - **WebCommonInterceptor**:可能是一种统一的拦截器...

    MAClusteringManager:Maker cluster for MAMapKit.支持高德地图SDK的点聚合控件

    MAClusteringManager ...由上述算法可见,如果不对annotaions以一种便于搜索的方式存储的话,每次需要找出一个Cell的点需要遍历一次所有annotaion,复杂度为O(N),N为annotaion个数,Cell个数为M的话

    Cluster Map View(iPhone源代码)

    来源:Licence:BSD平台:iOS设备:iPhone / iPad作者:Botond Kis  实现地图标注(Annotation)聚集...图片中圆圈越大的地方表示聚集的annotaion越多。 Code4App编译测试,适用环境:Xcode 4.3, iOS 5.0。

    Iono.Container:spring框架风格PHP服务容器库(带注解)

    : " * " , " iono/container " : " 0.* " },用法初始化介绍步骤1 制作目录结构创建与初始设置相关的文件$ php vendor/bin/init.container.php 默认结构 project root - resource(configure file, annotaion scanned ...

Global site tag (gtag.js) - Google Analytics