• 4.设计模式-策略模式(Strategy)


    strategy介绍

    主要解决:在有多种算法相似的情况下,使用 if...else 所带来的复杂和难以维护。

    意图:定义一系列算法,把它们一个个封装起来,并且使它们可互相替换(变化)。该模式使得算法可独立于使用它的客户程序(稳定)而变化(扩展,子类化)。

    如何解决:将这些算法封装成一个一个的类,通过工厂来实现任意地替换。

    优点:

    • 1、算法可以自由切换。
    • 2、避免使用多重条件判断。
    • 3、扩展性良好(每一个策略相当于一个类,减少依赖,松耦合)。

    缺点:

    • 1、策略类会增多。
    • 2、所有策略类都需要对外暴露。

    注意: 如果策略稳定不变的情况下,建议还是使用if…else,比如性别只有男女的情况、一周只有7天的情况.

     

    实现场景

    以支付支付宝、微信支付、银联支付及京东白条为例.

    在不使用策略模式之前是这样写的:

    //支付方式
    enum PayMode {
           AliPay,
           WeChatPay ,
           JDPay
    };
    
     
    class Payment{
        PayMode mode;
    public:
        bool pay(const Context& context){
            //...
            if (mode == AliPay){
                // 支付宝支付
            }
            else if (mode == WeChatPay){
                // 微信支付
            }
            else if (mode == JDPay){
                // 京东支付
            }
            //....
         }
    };

    假如以后又增加招商支付、信用卡支付等等的时候,我们都需要去增加一个enum值,然后添加else if语句, 维护起来也很难,尤其后续新增加不同情况的操作(信用卡支付未成功跳转到微信支付等等),还需要新增加if…else,耦合度太高。

    所以可以使用策略模式来将这些复杂的逻辑判断分成一个个单独的类,实现同一个接口或者继承于同一个父类.

    写法如下所示:

     

     


    人间有真情,人间有真爱。

    如果您喜欢这里,感觉对你有帮助,并且有多余的软妹币的话,不妨投个食吧,赞赏的时候,留下美句和你的博客地址哦~   戳这里看谁投食了


  • 相关阅读:
    查看mysql服务器连接
    读懂MySQL执行计划
    学会MySQL索引
    记一个有趣的Java OOM!
    高并发场景系列(一) 利用redis实现分布式事务锁,解决高并发环境下减库存
    如何优雅的使用mybatis
    禁止页面后退JS(兼容各浏览器)
    如何做一个对账系统
    centos7.2进入单用户模式修改密码
    linux系统引导流程
  • 原文地址:https://www.cnblogs.com/lifexy/p/14972274.html
  • Copyright © 2020-2023  润新知