使用动态代理无需修改一个逻辑方法的代码,便可以为它加上缓存功能,提高其性能。
现在,假设有一个可能被频繁调用的方法,它用于对一个整数做因式分解。实现如下:(由于本文不关注因式分解算法,故只列出该类的结构):
public class HeavyMethodDemo {
public String heavyMethod(int num) {
StringBuffer sb = new StringBuffer();
//对 num 进行因式分解,将结果保存在sb中
return sb.toString();
}
}
使用CGLIB生成动态代理类的方法拦截器的逻辑如下:
public class CglibHeavyMethodInterceptor implements MethodInterceptor {
HeavyMethodDemo real=new HeavyMethodDemo();
@Override
public Object intercept(Object arg0, Method arg1, Object[] arg2,
MethodProxy arg3) throws Throwable {
String v=(String)EHCacheUtil.get("cache1", (Serializable)arg2[0]); //查询缓存
if(v==null){
v=real.heavyMethod((Integer)arg2[0]); //缓存中未找到结果
EHCacheUtil.put("cache1", (Integer)arg2[0], v); //保存计算结果
}
return v;
}
现在,假设有一个可能被频繁调用的方法,它用于对一个整数做因式分解。实现如下:(由于本文不关注因式分解算法,故只列出该类的结构):
public class HeavyMethodDemo {
public String heavyMethod(int num) {
StringBuffer sb = new StringBuffer();
//对 num 进行因式分解,将结果保存在sb中
return sb.toString();
}
}
使用CGLIB生成动态代理类的方法拦截器的逻辑如下:
public class CglibHeavyMethodInterceptor implements MethodInterceptor {
HeavyMethodDemo real=new HeavyMethodDemo();
@Override
public Object intercept(Object arg0, Method arg1, Object[] arg2,
MethodProxy arg3) throws Throwable {
String v=(String)EHCacheUtil.get("cache1", (Serializable)arg2[0]); //查询缓存
if(v==null){
v=real.heavyMethod((Integer)arg2[0]); //缓存中未找到结果
EHCacheUtil.put("cache1", (Integer)arg2[0], v); //保存计算结果
}
return v;
}