Java动态代理

动态代理设计模式很可能在不知不觉中使用了,例如Spring中的AOP,Struts2中的拦截器等。
先来看静态代理模式代码:

package test;

/**
 * Created by ZhuHao on 2016/10/9.
 */
public interface Subject {
    public void doSomething();
}
package test;

/**
 * Created by ZhuHao on 2016/10/9.
 */
public class RealSubject implements Subject{
    public void doSomething(){
        System.out.println("call doSomething()");
    }
}
package test;

/**
 * Created by ZhuHao on 2016/10/9.
 */
public class SubjectProxy implements Subject {
    Subject subimpl = new RealSubject();
    public void doSomething(){
        subimpl.doSomething();
    }
}
package test;

/**
 * Created by ZhuHao on 2016/10/9.
 */
public class TestProxy {
    public static void main(String[] args) {
        Subject sub = new SubjectProxy();
        sub.doSomething();
    }
}

刚开始会觉得SubjectProxy定义出来纯属多余,直接实例化实现类完成操作多方便。后来随着业务庞大就会知道实现Proxy类对真实类的封装对于粒度的控制有着重要的意义。但是静态代理这个模式本身有个大问题,如果类方法数量越来越多的时候,代理类的代码量是十分庞大的。所以引入动态代理来解决此类问题。

先看代码:

package test;

/**
 * Created by ZhuHao on 2016/10/9.
 */
public interface Subject {
    public void doSomething();
}
package test;

/**
 * Created by ZhuHao on 2016/10/9.
 */
public class RealSubject implements Subject{
    public void doSomething(){
        System.out.println("call doSomething()");
    }
}
package test;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

/**
 * Created by ZhuHao on 2016/10/9.
 */
public class ProxyHandler implements InvocationHandler{
    private Object tar;

    //绑定委托对象,并返回代理类
    public Object bind(Object tar){
        this.tar = tar;
        //绑定该类实现的所有接口,取得代理类
        return Proxy.newProxyInstance(tar.getClass().getClassLoader(),tar.getClass().getInterfaces(),this);
    }

    public Object invoke(Object proxy, Method method, Object[] args)throws Throwable{
        Object result = null;
        //这里就可以进行所谓的AOP编程了
        //在调用具体函数方法前,执行功能处理
        result = method.invoke(tar,args);
        //在调用具体函数方法后,执行功能处理
        return result;
    }
}
package test;

/**
 * Created by ZhuHao on 2016/10/9.
 */
public class TestProxy {
    public static void main(String[] args) {
        ProxyHandler proxy = new ProxyHandler();
        //绑定该类实现的所有接口
        Subject sub = (Subject)proxy.bind(new RealSubject());
        sub.doSomething();
    }
}

看完代码,现在可以回答动态代理的作用是什么;
1.Proxy类的代码量被固定下来,不会因为业务的逐渐庞大而庞大;
2.可以实现AOP编程,实际上静态代理也可以实现,总的来说,AOP可以算作是代理模式的一个典型应用;
3.解耦,通过参数就可以判断真实类,不需要事先实例化,更加灵活多变。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值