java获取注解信息_java 自定义注解,获取注解信息

1.声明注解 @OneAnnotation

package com.wdletu.log.test;

import java.lang.annotation.*;

/**

* Created by zhangmy on 2017/7/25.

*/

@Target(ElementType.METHOD) // 这是一个对方法的注解,还可以是包、类、变量等很多东西

@Retention(RetentionPolicy.RUNTIME) // 保留时间,一般注解就是为了框架开发时代替配置文件使用,JVM运行时用反射取参数处理,所以一般都为RUNTIME类型

@Documented // 用于描述其它类型的annotation应该被作为被标注的程序成员的公共API,因此可以被例如javadoc此类的工具文档化

public @interface OneAnnotation {

// 定义注解的参数,类型可以为基本类型以及String、Class、enum、数组等,default为默认值

String parameter1() default "";

int parameter2() default -1;

}2.方法添加注解声明

package com.wdletu.log.test;

/**

* Created by zhangmy on 2017/7/25.

*/

public class OneClass {

@OneAnnotation(parameter1 = "YES", parameter2 = 10000)

public void oneMethod() {

}

}3.测试获取方法上声明注解

package com.wdletu.log.test;

import java.lang.reflect.Method;

/**

* Created by zhangmy on 2017/7/25.

*/

public class Test {

public static void main(String[] args) throws Exception {

String name = OneClass.class.getName();

// 提取到被注解的方法Method,这里用到了反射的知识

Method method = Class.forName(name).getDeclaredMethod("oneMethod");

// 从Method方法中通过方法getAnnotation获得我们设置的注解

OneAnnotation oneAnnotation = method.getAnnotation(OneAnnotation.class);

// 得到注解的俩参数

System.out.println(oneAnnotation.parameter1());

System.out.println(oneAnnotation.parameter2());

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值