package com.mzsx.gclib;
public class FunctionServerImp {
public void creatdDoc(int count) {
System.out.println("创建了"+count+"对象。。。。。。。");
}
public void removeDoc(int count) {
System.out.println("***了"+count+"对象。。。。。。。");
}
}
package com.mzsx.gclib;
public class Porformant {
private long start;
private long end;
public void start(){
System.out.println("执行start。。。。。");
start =System.currentTimeMillis();
}
public void end(){
end=System.currentTimeMillis();
System.out.println("耗时"+(end-start)+"ms........");
}
}
package com.mzsx.gclib;
import java.lang.reflect.Method;
import net.sf.cglib.proxy.Enhancer;
import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
public class CGlibProxy implements MethodInterceptor {
private Enhancer enhancer=new Enhancer();
public Object getProxy(Class clazz){
enhancer.setSuperclass(clazz);
enhancer.setCallback(this);
return enhancer.create();
}
@Override
public Object intercept(Object obj, Method method, Object[] arg,
MethodProxy proxy) throws Throwable {
Porformant porformant=new Porformant();
porformant.start();
Object object=proxy.invokeSuper(obj, arg);
porformant.end();
return object;
}
}
package com.mzsx.gclib;
public class CGlibTest {
public static void main(String[] args) {
CGlibProxy cGlibProxy=new CGlibProxy();
FunctionServerImp functionServerImp=(FunctionServerImp)cGlibProxy.getProxy(FunctionServerImp.class);
functionServerImp.creatdDoc(10);
functionServerImp.removeDoc(20);
}
}
对比JDK的AOP与CGlib的AOP:
1、JDK的AOP的proxy需要依赖与接口,而CGLib的APO不需要依赖接口;
2、JDK的AOP生成实例速度快,但是执行效率慢,CGLib刚好相反,是生成实例慢,执行效率快;
3、CGLIB是针对类实现代理,主要是对指定的类生成一个子类,覆盖其中的方法
因为是继承,所以该类或方法最好不要声明成final
动态代理的本质:
用来实现对目标对象进行增强,最终表现为类,只不过是动态创建子类,不用手工生成子类。
动态代理的限制:
只能在父类方法被调用之前或之后进行增强(功能的修改),不能在中间进行修改,要想在方法调用中增强,需要ASM(一个Java 字节码操作和分析框架)
转载于:https://blog.51cto.com/qiangmzsx/1367219