欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > 文章正文

java 动态代理,

来源: javaer 分享于  点击 15872 次 点评:288

java 动态代理,


cglib 动态代理:
需要引入 cglib.jar

    代理类:

public class CglibProxyFactory  implements MethodInterceptor {
    private  Object target;
    public  CglibProxyFactory(Object target){
        this.target=target;
    }

    public  Object getProxyInstance(){
        // 工具类
        Enhancer enhancer= new Enhancer();
        //设置父类
        enhancer.setSuperclass(target.getClass());
        //回调函数
        enhancer.setCallback(this);
        //创建子类
        return  enhancer.create();

    }
    @Override
    public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
        System.out.println("—————————cglib———————————————Proxy start");
        //执行目标对象方法
        Object returnValue = method.invoke(target, objects);
        System.out.println("———————————cglib—————————————Proxy end  ");
        return returnValue;
    }
}
测试:
//cglib 代理
Person cglibproxyFactory = (Person) new CglibProxyFactory(person).getProxyInstance();
//代理对象 com.chf.proxy.Boy$$EnhancerByCGLIB$$a1a0404c
System.out.println(cglibproxyFactory.getClass());
//执行代理方法
cglibproxyFactory.say();
深入理解CGLIB动态代理机制
Cglib动态代理实现原理

三种代理方式之间对比。

代理方式实现优点缺点特点
JDK静态代理代理类与委托类实现同一接口,并且在代理类中需要硬编码接口实现简单,容易理解代理类需要硬编码接口,在实际应用中可能会导致重复编码,浪费存储空间并且效率很低好像没啥特点
JDK动态代理代理类与委托类实现同一接口,主要是通过代理类实现InvocationHandler并重写invoke方法来进行动态代理的,在invoke方法中将对方法进行增强处理不需要硬编码接口,代码复用率高只能够代理实现了接口的委托类底层使用反射机制进行方法的调用
CGLIB动态代理代理类将委托类作为自己的父类并为其中的非final委托方法创建两个方法,一个是与委托方法签名相同的方法,它在方法中会通过super调用委托方法;另一个是代理类独有的方法。在代理方法中,它会判断是否存在实现了MethodInterceptor接口的对象,若存在则将调用intercept方法对委托方法进行代理可以在运行时对类或者是接口进行增强操作,且委托类无需实现接口不能对final类以及final方法进行代理底层将方法全部存入一个数组中,通过数组索引直接进行方法调用


相关文章

    暂无相关文章
相关栏目:

用户点评