您的位置:首页 > 编程语言 > Java开发

JAVA注释应用小例子

2016-11-16 14:33 253 查看
Java自定义注释的两个应用:

第一个应用相当于获取配置文件的值。

定义一个注释,代码如下:

package note;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
* 定义一个注解
*/
@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;
}


应用这个注释,代码如下:

package note;

/**
* 一个用到了自定义的注解的类
*/
public class OneClass {

@OneAnnotation(parameter1="YES", parameter2=10000)
public void oneMethod () {
}
}


测试代码如下:

package note;

import java.lang.reflect.Method;

public class TestThis {

public static void main(String[] args) throws Exception {
// 提取到被注解的方法Method,这里用到了反射的知识
Method method = Class.forName("note.OneClass").getDeclaredMethod("oneMethod");
// 从Method方法中通过方法getAnnotation获得我们设置的注解
OneAnnotation oneAnnotation = method.getAnnotation(OneAnnotation.class);

// 得到注解的俩参数
System.out.println(oneAnnotation.parameter1());
System.out.println(oneAnnotation.parameter2());
}
}


实验结果:

YES
10000


代码解释:

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

执行oneMethod方法的时候就把参数传递到oneAnnotation中。假设一个情景,当我们需要在配置文件里面设置参数的时候,我们每更改一次配置文件的参数的值,我们都需要读取配置文件并且把配置文件里面的值进行修改,我们使用自定义注解的时候,我们就可以在调用方法前把参数提交,不用频繁读取配置文件,并且修改配置文件的参数值。

第二个应用设置拦截器:

当我们需要在前台页面显示操作数据库的人的信息的时候,我们需要设置一个拦截器,在操作数据库的方法的前面进行拦截,获取操作人的信息和操作记录。

这个时候我们就可以自定义一个注释,里面有两个参数,一个是操作人,一个操作记录(增删查改)。

然后我们写一个拦截器,拦截调用了带有上面注释的方法。获取参数值。

综合上面的我们看到其实注释是建立在反射的基础上面,让我们更加深刻理解反射的作用之大。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: