Java自定义注解并通过反射读取

自定义注解

  1. 使用@interface自定义注解,自动继承了java.lang.annotation接口

  2. 格式为:

    • public @interface 注解名 {定义体}
    • 其中的每个方法实际上是声明了一个配置参数
    • 方法的名称就是参数的名称
    • 返回值的参数就是参数的类型(返回值类型只能是基本类型、Class、String、enum)
    • 可以通过default来声明参数的默认值。
    • 如果只有一个参数成员,一般参数名为value
  3. 注意:注解元素必须要有值。我们定义注解元素时,经常使用空字符串、0作为默认值。 也经常使用负数(比如:-1)表示不存在的含义

元注解

  1. 元注解的作用就是负责注解其他注解。Java定义了4个标准的meta-annotation类型,他们被用来提供对其他annotation类型作说明。
  2. 这些类型和它们所支持的类在java.lang.annotation包中可以 找到
  • @Target
  • @Retention
  • @Documented
  • @Inherited

@Target

  1. 作用:用于描述注解的使用范围(即:被描述的注解可以用在什么地方)
所修饰范围取值ElementType
package 包PACKAGE
类、接口、枚举、Annotation类型TYPE
类型成员(方法、构造方法、成员变量、枚举值)CONSTRUCTOR:用于描述构造器
FIELD:用于描述域
METHOD:用于描述方法
方法参数和本地变量LOCAL_VARIABLE:用于描述局部变量
PARAMETER:用于描述参数
  1. 例如:@Target(value=ElementType.TYPE)

@Retention

  1. 作用:表示需要在什么级别保存该注释信息,用于描述注解的生命周期
取值RetentionPolicy作用
SOURCE在源文件中有效(即源文件保留)
CLASS在class文件中有效(即class保留)
RUNTIME在运行时有效(即运行时保留)
为Runtieme可以被反射机制读取

使用反射机制读取注解信息

try { 
	Class clazz = Class.forName("com.wj.test.annotation.WjtStudent");
	 
	//获得类的所有有效注解 
	Annotation[] annotations=clazz.getAnnotations(); 
	for (Annotation a : annotations) { 
			System.out.println(a); 
		}
		//获得类的指定的注解 
		WjTable wt = (WjTable) clazz.getAnnotation(WjTable.class);  
		System.out.println(wt.value()); 
		//获得类的属性的注解 
		Field f = clazz.getDeclaredField("studentName"); 
		WjField wjField = f.getAnnotation(WjField.class); 
		System.out.println(wjField.columnName()+"--"+wjField.type()+"--"+wjField.length()); 
} catch (Exception e) { 
		e.printStackTrace(); 
	}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值