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

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

  • 相关阅读:
    【云原生】Secret敏感信息存储
    中学教学参考杂志中学教学参考编辑部中学教学参考杂志社2022年第18期目录
    阿里,腾讯,百度等大厂都在采用的Git,据说都来脱形自这份文档
    2023年最大规模的IPO正式诞生,Arm市值4700亿
    利用正则表达式限制网页表单里的文本框输入内容
    The Missing Semester
    网攻西北工业大学的美国安局人员真实身份锁定!
    2023年第三届HiPChips解读
    解决了个bug,想说点啥但又难以启齿
    23种设计模式之命令模式(Command Pattern)
  • 原文地址:https://blog.csdn.net/qq_39751120/article/details/127588643