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、付费专栏及课程。

余额充值