结合项目实例 回顾传统设计模式(一)策略模式

简介:

虫子以前在一家电商公司 会员的模块在这里分类很明确

不同的会员所具有的权限和行为不同,大多程序员会使用标准的oo技术,设计一个会员超类SuperUser,并让各种商家会员继承此超类

到这里无可厚非,但是在下面个过程中你可以就慢慢体会策略模式与你在代码里不停写逻辑判断所带来的区别有多大

所有的会员都具有下列行为
购物,评价,发布商品

View Code
public  abstract  class SuperUser
    {
         public SuperUser()
        {
        }
         public  void shopping()
        {
            Console.WriteLine( " shopping ");
        }
         public  void Comment()
        {
            Console.WriteLine( " Comment ");
        }
         public  abstract  void Promote();
        
    }
     public  class UserA : SuperUser
    {
         public  override  void Promote()
        {
            Console.WriteLine( " 推广A类商品 ");
        }
    }
     public  class UserB : SuperUser
    {
         public  override  void Promote()
        {
            Console.WriteLine( " 推广B类商品 ");
        }
    }

因为不同商家会员只能推广指定类型的商品所以这里Promote方法抽象出来

好吧 现在我们来了一个新需求 对于B类的用户 进行购物折价

加在什么地方 超类? 不 并不是所有的会员都拥有折价 逻辑判断? 是个方法 不过对于不断需求的变更 在庞大臃肿的领域模型中 时间长了 也hold不住 更何况还不停有不同的商家会员分类加进来 并且在大型web架构中作为基站的程序不适合频繁更新

既然这样 利用接口如何 对改变关闭 对扩展开放

View Code
public  interface discountBehavior
    {
          void discount();
    }

     public  class diswithB : discountBehavior
    {
         public  void discount()
        {
            Console.WriteLine( " 能打折扣呃 ");
        }
    }

     public  class Nodis : discountBehavior
    {
         public  void discount()
        {
            Console.WriteLine( " 不能打折扣 ");
        }
    }

     public  abstract  class SuperUser
    {
         public SuperUser()
        {
        }
         public  void shopping()
        {
            Console.WriteLine( " shopping ");
        }
         public  void Comment()
        {
            Console.WriteLine( " Comment ");
        }
         public  abstract  void Promote();

         public discountBehavior dcbehavior;
         public  void discount()
        {
            dcbehavior.discount();
        }
        
    }
     public  class UserA : SuperUser, discountBehavior
    {
         public UserA()
        {
            dcbehavior =  new Nodis();
        }
         public  override  void Promote()
        {
            Console.WriteLine( " 推广A类商品 ");
        }
    }
     public  class UserB : SuperUser, discountBehavior
    {
         public UserB()
        {
            dcbehavior =  new diswithB();
        }
         public  override  void Promote()
        {
            Console.WriteLine( " 推广B类商品 ");
        }
    }

下面我们再来试试动态设定行为

在超类中加个方法

View Code
  public  void setdiscountBehavior(discountBehavior dh)
        {
            dcbehavior = dh;
        }

这样就可以“随时”调用这个方法 改变会员的行为

 

总结:

策略模式:针对接口编程,而不是针对实现编程。多用组合少用继承。策略模式定义了算法簇,分别封装起来,让它们之间可以互相替换,此模式让算法的变化独立于使用算法的客户。

 



本文转自 熬夜的虫子  51CTO博客,原文链接:http://blog.51cto.com/dubing/712402

相关文章
|
11天前
|
设计模式 算法 PHP
php设计模式--策略模式(六)
php设计模式--策略模式(六)
11 0
|
3月前
|
设计模式 算法 搜索推荐
设计模式之策略模式
设计模式之策略模式
41 0
|
3月前
|
设计模式 算法 Java
行为型设计模式-策略模式(Strategy Pattern)
行为型设计模式-策略模式(Strategy Pattern)
|
6月前
|
设计模式 缓存 算法
JAVA设计模式14:策略模式,使算法的变化独立于使用它的客户端
JAVA设计模式14:策略模式,使算法的变化独立于使用它的客户端
|
3月前
|
设计模式 算法 Java
【设计模式】策略模式在数据接收和发送场景的应用
在数据接收和发送场景打算使用了if else进行判断。ASystem.sync("向A同步数据");BSystem.sync("向B同步数据");...非常麻烦,需求多了很臃肿!策略模式(Strategy Pattern)定义了一组同类型的算法,在不同的类中封装起来,每种算法可以根据当前场景相互替换,从而使算法的变化独立于使用它们的客户端(即算法的调用者)。// 创建两个策略对象// 创建上下文对象,并传入策略对象。
58 1
|
4月前
|
设计模式 算法
设计模式思考,简单工厂模式和策略模式的区别?
设计模式思考,简单工厂模式和策略模式的区别?
|
4月前
|
设计模式 Java
细说一下设计模式中的策略模式!
细说一下设计模式中的策略模式!
30 0
|
5月前
|
设计模式 算法 关系型数据库
设计模式系列教程(13) - 策略模式
设计模式系列教程(13) - 策略模式
22 0
|
1月前
|
设计模式 算法 Java
【设计模式】策略模式
【设计模式】策略模式
|
3月前
|
设计模式 算法 自动驾驶
常见的设计模式(模板与方法,观察者模式,策略模式)
随着时间的推移,软件代码越来越庞大,随着而来的就是如何维护日趋庞大的软件系统。在面向对象开发出现之前,使用的是面向过程开发来设计大型的软件程序,面向过程开发将软件分成一个个单独的模块,模块之间使用函数进行组合,最后完成系统的开发,每次需要修改软件,如果不涉及好各个模块的关系,就会导致软件系统难以维护,从而导致软件变得不可使用。面向对象方法用对象模拟问题域中的实体,以对象间的联系刻画实体间联系
63 2