• java设计模式之外观代理模式


    什么是代理模式?为什么要使用代理模式?

    代理模式属于结构型,通过目标对象类完成其实现。

    静态代理静态代理要求目标对象和代理对象实现同一个业务接口,由目标类去创建和实现,代理类负责实现增强。

    静态代理的缺点:代理类和目标类实现了相同的接口,每个代理都需要实现目标类的方法,冗余代码,业务方法繁多不易于拓展和维护,正常不通service提供不同的业务方法,多个相同的业务方法由多个service实现,就会导致这样的问题。

    代理模式的应用场景:监控、统计、鉴权、限流、事务、幂等、日志,缓存都可以使用代理帮助我们解耦程序,程序的核心是增强我们业务能力。

    jdk动态代理实现:通过实现InvocationHandler类,实现invoke方法,通过Proxy类方法newProxyInstance传入当前类接口类和方法构造器,当前反射handler 从而获取具体目标实现类的实例。

    这里使用我们之前说过的适配器模式,通过适配充电器支持安卓和苹果充电器。

    jdk动态代理:

    invocation类:

    1. package com.xy.design.proxy.handler;
    2. import java.lang.reflect.InvocationHandler;
    3. import java.lang.reflect.Method;
    4. public class Invocation implements InvocationHandler {
    5. private Object obj;
    6. public Invocation(Object obj) {
    7. this.obj = obj;
    8. }
    9. @Override
    10. public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
    11. Object object = method.invoke(obj, args);
    12. return object;
    13. }
    14. }

     jdk类图:

    1. //jdk动态代理
    2. AppleChargerService appleChargerService = new AppleChargerServiceImpl();
    3. //实现invoke方法
    4. Invocation invocation = new Invocation(appleChargerService);
    5. //创建构造实例化对象
    6. AppleChargerService chargerService = (AppleChargerService) Proxy.newProxyInstance(
    7. appleChargerService.getClass().getClassLoader(),
    8. appleChargerService.getClass().getInterfaces(),
    9. invocation
    10. );
    11. chargerService.appleBusiness();

    cglib动态代理:

    1. AppleChargerService appleChargerService = new AppleChargerServiceImpl();
    2. // 通过CGLIB动态代理获取代理对象
    3. Enhancer enhancer = new Enhancer();
    4. // 设置enhancer对象的父类
    5. enhancer.setSuperclass(AppleChargerService.class);
    6. // 设置enhancer的回调对象
    7. enhancer.setCallback(new Invocation(appleChargerService));
    8. // 创建代理对象
    9. AppleChargerService chargerService = (AppleChargerService)enhancer.create();
    10. chargerService.appleBusiness();

    类图:

    注意事项:jdk动态代理和cglib动态代理都有InvocationHandler 类引用的时候注意包就行

    import java.lang.reflect.InvocationHandler;
    
    import net.sf.cglib.proxy.InvocationHandler;
    

     动态代理和静态代理的区别:动态代理支持动态字节码技术,可以实现热更新,通过我们类加载器实现jvm程序执行引擎,而静态代理是由目标类完成代码相当于proxy类完成代理实现目标方法,静态代理不易于拓展和移植,代码结构变得冗余和沉重。

     ————没有与生俱来的天赋,都是后天的努力拼搏(我是小杨,谢谢你的关注和支持)

  • 相关阅读:
    Linux安装redis详细教程
    计算机毕业设计node+vue基于微信小程序的美甲店铺座位预约系统的设计与实现
    java计算机毕业设计动漫论坛系统MyBatis+系统+LW文档+源码+调试部署
    Mybatis第三天
    RuoYi-App启动教程
    速卖通获得aliexpress商品详情 API 返回值说明
    树模型(三)决策树
    链表经典题带刷(内含精华:链表深拷贝)
    由ASP.NET Core读取Response.Body引发的思考
    动态规划 - 背包问题 & 回文串分割
  • 原文地址:https://blog.csdn.net/qq_39751120/article/details/127588643