前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >4.设计模式-策略模式(Strategy)

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

作者头像
诺谦
发布2021-07-08 15:03:33
4220
发布2021-07-08 15:03:33
举报
文章被收录于专栏:Linux驱动Linux驱动

strategy介绍

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

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

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

优点:

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

缺点:

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

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

实现场景

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

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

代码语言:javascript
复制
//支付方式
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,耦合度太高。

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

写法如下所示:

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-07-05 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档