• 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类完成代理实现目标方法,静态代理不易于拓展和移植,代码结构变得冗余和沉重。

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

  • 相关阅读:
    LeetCode50天刷题计划(Day 41 —颜色分类(13.00-14.10)
    DNSLog原理及代码实现
    第3.1章:StarRocks数据导入——Insert into 同步模式
    第八章——权限管理与备份
    (2022版)一套教程搞定k8s安装到实战 | ConfiMap
    vue3 组件与API直接使用,怎样无需import?
    Excel Unix时间戳和日期时间格式的相互转换
    LeetCode-77-组合
    Ubuntu Linux 24.04 安装apache web server操作记录
    Python每日一练(牛客新题库)——第21天:内置函数
  • 原文地址:https://blog.csdn.net/qq_39751120/article/details/127588643