java注解处理
package com.yc.annotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* 给方法添加日志处理
* @author jp
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface MyLog {
Class<?> value();
}
package com.yc.annotation;
/**
* 计算器业务处理接口
* @author jp
*
*/
public interface Calculator {
int add(int num01, int num02);//加法操作
int divid(int num01, int num02);//除法操作
}
package com.yc.annotation.impl;
import com.yc.annotation.Calculator;
import com.yc.annotation.MyLog;
/**
* 计算器业务处理实现类
* @author jp
*
*/
public class CalculatorImpl implements Calculator {
@MyLog(CalculatorLogging.class)
public int add(int num01, int num02) {
int result = num01 + num02;
System.out.println(num01 + " + " + num02 + " = " + result);
return result;
}
public int divid(int num01, int num02) {
int result = num01 / num02;
System.out.println(num01 + " / " + num02 + " = " + result);
return result;
}
}
3.日志处理
package com.yc.annotation;
/**
* 日志处理接口
* @author jp
*/
public interface ILogging {
public void beginMethod(String methodName, Object...params); //前置处理日志
public void afterMethod(String methodName, Object result);//后置处理日志
}
package com.yc.annotation.impl;
import java.util.Arrays;
import com.yc.annotation.ILogging;
/**
* 日志处理实现类
* @author jp
*/
public class CalculatorLogging implements ILogging{
public void beginMethod(String methodName, Object...params){
System.out.println(methodName + "开始计算,计算数据是:" + Arrays.toString(params));
}
public void afterMethod(String methodName, Object result){
System.out.println(methodName + "计算完成,计算结果是:" + result);
}
}
4.代理注解解析处理类
package com.yc.annotation.impl;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import com.yc.annotation.Calculator;
import com.yc.annotation.ILogging;
import com.yc.annotation.MyLog;
/**
* 计算器处理的动态代理对象
* @author jp
*/
public class ProxyCalculator {
/**
* @param c 具体要执行处理的实现类的接口类型
* @return 代理对象
*/
public Calculator getInstance(final Calculator c) {
ClassLoader loader = c.getClass().getClassLoader();
Class<?>[] interfaces = c.getClass().getInterfaces();
InvocationHandler h = new InvocationHandler() {
/* 代理对象回调处理函数
* proxy代理对象
* method代理执行的方法
* args执行方法的参数
*/
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
Method m = c.getClass().getMethod(method.getName(), method.getParameterTypes()); //取到具体执行的方法类对象
Object result = null;
if (m.isAnnotationPresent(MyLog.class)) { //判断方法是否被注解
MyLog ml = m.getAnnotation(MyLog.class); //取到注解对象
ILogging cl = (ILogging) ml.value().newInstance(); //取到注解对象的参数值
cl.beginMethod(method.getName(), args); //前置处理日志
result = method.invoke(c, args);//执行方法
cl.afterMethod(method.getName(), result);//后轩算是日志
} else {
result = method.invoke(c, args); //执行方法
}
return result;
}
};
return (Calculator) Proxy.newProxyInstance(loader, interfaces, h); //创建代理对象
}
}
5.测试处理结果
package com.yc.annotation;
import static org.junit.Assert.*;
import org.junit.Test;
import com.yc.annotation.impl.CalculatorImpl;
import com.yc.annotation.impl.ProxyCalculator;
public class CalculatorTest {
@Test
public void testMethodAnnot() throws InstantiationException, IllegalAccessException {
Calculator c = new ProxyCalculator().getInstance(new CalculatorImpl());
int result = c.add(12, 23); //加了日志注解的测试
assertEquals(35, result);
System.out.println("=========================");
c.divid(4, 2); //没有加日志注解的测试
assertEquals(2, result);
}
}
结果:
4 / 2 = 2
java注解处理的更多相关文章
- Java注解
Java注解其实是代码里的特殊标记,使用其他工具可以对其进行处理.注解是一种元数据,起到了描述.配置的作用,生成文档,所有的注解都隐式地扩展自java.lang.annotation.Annotati ...
- 19.Java 注解
19.Java注解 1.Java内置注解----注解代码 @Deprecated //不推荐使用的过时方法 @Deprecated ...
- Java注解入门
注解的分类 按运行机制分: 源码注解:只在源码中存在,编译后不存在 编译时注解:源码和编译后的class文件都存在(如@Override,@Deprecated,@SuppressWarnin ...
- java注解(Annotation)解析
注解(Annotation)在java中应用非常广泛.它既能帮助我们在编码中减少错误,(比如最常见的Override注解),还可以帮助我们减少各种xml文件的配置,比如定义AOP切面用@AspectJ ...
- JAVA 注解的几大作用及使用方法详解
JAVA 注解的几大作用及使用方法详解 (2013-01-22 15:13:04) 转载▼ 标签: java 注解 杂谈 分类: Java java 注解,从名字上看是注释,解释.但功能却不仅仅是注释 ...
- attilax.java 注解的本质and 使用最佳实践(3)O7
attilax.java 注解的本质and 使用最佳实践(3)O7 1. 定义pojo 1 2. 建立注解By eclipse tps 1 3. 注解参数的可支持数据类型: 2 4. 注解处理器 2 ...
- paip.java 注解的详细使用代码
paip.java 注解的详细使用代码 作者Attilax 艾龙, EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/att ...
- JAVA 注解的几大作用及使用方法详解【转】
java 注解,从名字上看是注释,解释.但功能却不仅仅是注释那么简单.注解(Annotation) 为我们在代码中添加信息提供了一种形式化的方法,是我们可以在稍后 某个时刻方便地使用这些数据(通过 解 ...
- 框架基础——全面解析Java注解
为什么学习注解? 学习注解有什么好处? 学完能做什么? 答:1. 能够读懂别人写的代码,特别是框架相关的代码: 2. 让编程更加简洁,代码更加清晰: 3. 让别人高看一眼. spring.mybati ...
- Java注解配置
Java注解是附加在代码中的一些元信息,用于一些工具在编译.运行时进行解析和使用,起到说明.配置的功能.注解不会也不能影响代码的实际逻辑,仅仅起到辅助性的作用.包含在 java.lang.annota ...
随机推荐
- JNI开发的常见错误
1. 写错了load的library java.lang.UnsatisfiedLinkError: Couldn't load hell0: findLibrary returned null 2. ...
- 全局变量都是window对象的属性
var x = "haha"; var test = function(){ alert(this.x); } 上述,则会弹出 haha的值. 因为在JavaScript的变量作 ...
- CSS实例练习
蓝色导航为图片,用background-image实现. 排版用到ul,li标签,下划线运用border-bottom中的dashed,右边文字用到CSS浮动float. 实例: 代码: <!D ...
- Node.js 安装配置
1.安装常用工具: [root@em-nodejs /]# yum -y install vim wget xz 2.下载Node.js二进制安装包: [root@em-nodejs /]# wget ...
- Sublime 插件- px 转rem
一个CSS的px值转rem值的Sublime Text 3自动完成插件. 插件效果如下: 安装 克隆项目 https://github.com/hyb628/cssrem.git 进入packag ...
- Angularjs兼容IE
http://www.tuicool.com/articles/EJv6riY http://www.angularjs.cn/A00v http://www.cnblogs.com/ahl5esof ...
- bootstrap学习笔记--bootstrap组件
前面已经学习了bootstrap环境搭建以及基本布局方面的知识,下面将学习下关于bootstrap的相关组件,知识点有点多. 关于bootstrap组件知识点目录: Bootstrap--代码显示 B ...
- C语言产生标准正态分布或高斯分布随机数
C语言 产生标准正态分布或高斯分布 随机数 产生正态分布或高斯分布的三种方法: 1. 运用中心极限定理(大数定理) #include #include #define NSUM 25 double g ...
- G:首页调用“图片视频”的分类和文章(难点)
1:后台获取:自定义分类的ID (默认分类也可获取) 2:动态获取"自定义分类的ID($cat)" $cat_title = single_cat_title(' ', f ...
- 8Spring初步----青软S2SH(笔记)
例子: bean.xml <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=" ...