代理模式

代理模式在java 中的使用很常见,在Android中使用更为常见,类似代理一些生命周期,或者AOP编程以及业务解耦等等使用场景。

  • 代理模式分为静态代理和动态代理。

静态代理

interface BaseView {
    void showText();
}

class ProxyView implements BaseView{
    public static final String TAG = BaseView.class.getSimpleName();
    @Override
    public void showText() {
        Log.d(TAG, "niubility");
    }
}


class UserProxyView implements BaseView{
    public static final String TAG = UserProxyView.class.getSimpleName();
    UserProxyView mView = new UserProxyView();

    @Override
    public void showText() {
        mView.showText();
        Log.d(TAG, "niubility +1");
    }
}

public class Test{
    public static void test(){
        UserProxyView view = new UserProxyView();
        view.showText();
        // niubility
        // niubility +1
    }
}
  • 1.以上是最简单的静态代理的demo,可以看到通过代理模式,适合衍生对业务来进行解耦。但随着业务量巨大的情况下,基类也来越多,会造成代码量越来越多。

动态代理

动态代理一般用来解耦和aop进行埋点操作。其实尝试过用这种模式来进行解耦,但是由于过于复杂,可以简略一下,用其思想,对Activity 或者Fragment 等的生命周期进行代理,将耦合业务剥离出去。

public class DynamicProxy {
    public static void main(String[] args) {
        ProxyHandler handler = new ProxyHandler();
        DynamicBaseView view = (DynamicBaseView) handler.setProxyObject(new ProxyDynamicView());
        view.showText();
    }
}

interface DynamicBaseView {
    void showText();
}


class ProxyDynamicView implements BaseView {
    public static final String TAG = ProxyDynamicView.class.getSimpleName();

    @Override
    public void showText() {
        Log.d(TAG, "niubility Dynamic");
    }
}

class ProxyHandler implements InvocationHandler {
    public static final String TAG = ProxyHandler.class.getSimpleName();
    private Object mObject;

    public Object setProxyObject(Object o) {
        mObject = 0;

        return Proxy.newProxyInstance(mObject.getClass().getClassLoader(),
                mObject.getClass().getInterfaces()
                , this);
    }

    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        // AOP
        // 切入前操作
        Object obj = method.invoke(mObject, args);
        Log.d(TAG, "niubility Dynamic +1");
        // 切入后操作
        return obj;
    }
}
  • InvocationHandler java 已经为我们提供了动态代理机制,简单了解便可以直接拿来用了。
  • 动态代理机制就实现了AOP 编程。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值