head first 设计模式 策略模式

HEAD
FIRST
:策略模式定义了算法族,分别封装起来,让它们之间可以互相替换,此模式让算法的变化独立于使用算法的客户。

设计模式:定义一系列的算法,把它们一个个封装起来,并且使它们可以相互替换。本模式使得算法可独立于它的客户而变化。

大话设计模式:它定义了算法家族,分别封装起来,让它们之间可以互相替换,此模式让算法的变化,不会影响到使用算法的客户。

使用这个模式的原因:

用许多的算法对一类进行计算。那么如果把这些算法强行编码到这个类当中。其实是不可取的.因为很多时候下不同的情况下使用不同的算法。如果要添加新的算法也比较麻烦。如果一次性就包含了所有的算法那就很庞大了。

设计原则一:找出应用中可能需要变化之处,把他们独立出来,不要和那些不需要变化的代码混在一起.

这里变化的代码是说.各种可能会变化的Strategy.也就是一些行为或者算法.把会变化的部分取出来并“封装”起来,好让其他部分不受到影响。

设计原则二:针对接口编程:关键在于多态,执行时可以根据实际情况执行到真正的行为,不会被绑定到固定的行为上。通常来说,变量的声明类型一遍是抽象类或者接口。如此,只要是具体实现次超类型的类所产生的对象,都可以指定给这个声明的变量。也就是说。声明类的时候不需要理会以后执行时候对应的真正的类型对象。

设计原则三:多用组合 少用继承.

小理解:

Context中有一个Strategy的引用.他可以在Strategy的子类来实例化.也可以动态的改变..赋予某一个子类的实例.然后在Context中用一个方法来实现这个引用->Algorithminterface()...差不多就是这个意思...

如下:Duck类是 Context

然后FlyBehavior QuackBehavior是Strategy 类

在Duck类中的两个引用

FlyBehavior* flys;

 QuackBehavior *quas;

好吧~~基本明白了吧~~


  1 #include "stdafx.h"
2 #include<iostream>
3 using namespace std;
4 class FlyBehavior
5 {
6 public:
7 virtual void fly()=0;
8 };
9
10 class QuackBehavior
11 {
12 public:
13 virtual void quack()=0;
14 };
15 class guaguaQuack:public QuackBehavior
16 {
17 virtual void quack()
18 {
19 cout<<"guaguaQuack"<<endl;
20 }
21 };
22 class wangwangQuack:public QuackBehavior
23 {
24 virtual void quack()
25 {
26 cout<<"wangwangQuack"<<endl;
27 }
28 };
29 class noQuack:public QuackBehavior
30 {
31 virtual void quack()
32 {
33 cout<<"keepSilent"<<endl;
34 }
35 };
36 class CanFly:public FlyBehavior
37 {
38 virtual void fly()
39 {
40 cout<<"I can fly"<<endl;
41 }
42 };
43 class CannotFly:public FlyBehavior
44 {
45 virtual void fly()
46 {
47 cout<<"I cannot fly"<<endl;
48 }
49 };
50
51 class Duck
52 {
53 public:
54 FlyBehavior* flys;
55 QuackBehavior *quas;
56 virtual void display()=0;
57 void setFlyBehavier(FlyBehavior *f)
58 {
59 flys = f;
60 }
61 void setQuackBehavior(QuackBehavior *q)
62 {
63 quas = q;
64 }
65 void performFly()
66 {
67 flys->fly();
68 }
69 void performQua()
70 {
71 quas->quack();
72 }
73 void performSwim()
74 {
75 cout<<"i can swim...all the ducks"<<endl;
76 }
77 };
78
79 class modelDuck:public Duck
80 {
81 public:
82 modelDuck()
83 {
84 flys = new CannotFly;
85 quas = new noQuack;
86 }
87 virtual void display()
88 {
89 cout<<"this is a model duck"<<endl;
90 }
91 };
92
93 int _tmain(int argc, _TCHAR* argv[])
94 {
95 Duck *d = new modelDuck;
96 d->display();
97 d->performFly();
98 d->setFlyBehavier(new CanFly);
99 d->performFly();
100 //d->performQua();
101 //d->performSwim();
102 return 0;
103 }

head first 设计模式 策略模式

时间: 2024-10-27 13:37:20

head first 设计模式 策略模式的相关文章

设计模式 - 策略模式(Strategy Pattern) 具体解释

策略模式(Strategy Pattern) 具体解释 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26577879 本文版权全部, 禁止转载, 如有须要, 请站内联系. 策略模式: 定义了算法族, 分别封装起来, 让它们之间能够相互替换, 此模式让算法的变化独立于使用算法的客户. 对于父类的子类族须要常常扩展新的功能, 为了使用父类比較灵活的加入子类, 把父类的行为写成接口(interface)的形式; 使用set()方法

设计模式 - 策略模式(Strategy Pattern) 详解

策略模式(Strategy Pattern) 详解 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26577879 本文版权所有, 禁止转载, 如有需要, 请站内联系. 策略模式: 定义了算法族, 分别封装起来, 让它们之间可以相互替换, 此模式让算法的变化独立于使用算法的客户. 对于父类的子类族需要经常扩展新的功能, 为了使用父类比较灵活的添加子类, 把父类的行为写成接口(interface)的形式; 使用set()方法,

2.大话设计模式-策略模式

1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 7 namespace DesignModel 8 { 9 /// <summary> 10 /// 策略模式 11 /// </summary> 12 public class TacticsModel 13 { 14 //对于

设计模式---策略模式Strategy(对象行为型)

1. 概述 策略模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换.策略模式让算法独立于使用它的客户而独立变化. 策略模式是对算法的封装,它把算法的责任和算法本身分割开,委派给不同的对象管理. 2. 应用场景 (1)多个类只区别在表现行为不同,在运行时动态选择具体要执行的行为. (2)需要在不同情况下使用不同的策略(算法),或者策略还可能在未来用其它方式来实现. (3)对客户隐藏具体策略(算法)的实现细节,彼此完全独立. 3. 示例 出行旅游:我们可以有几个策略可以考虑:可

设计模式—策略模式

什么是策略模式? 策略模式定义了算法家族,分别封装起来,让它们之间能够相互替换,此模式让算法的变化不会影响到使用算法 的客户. 策略模式是一种定义一系列算法的方法,从概念上看全部这些算法完毕的都是同样的工作,仅仅是实现不同,它可 以以同样的方式调用全部的算法,降低了各种算法类与使用算法之间的耦合. 策略模式的长处? (1)策略模式的Strategy类层为Context类定义了一系列的可供重用的算法和行为.继承有助于析取出这些算法 的公共功能. (2)简化了单元測试(每一个算法都有自己的类,能够通

说说设计模式~策略模式(Strategy)

策略模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换.而对于客户端(UI)来说,可以通过IOC再配合工厂模块,实现动态策略的切换,策略模块通常于一个抽象策略对象(interface or abstract class),多个具体策略对象(implement class )和一个调用策略的入口组成. 何时能用到它? 对于UI来说,可能一个功能会有多种实现方式,而且实现方式可能还会有扩展,例如,一个ATM机,它目前支持工行,建行,家行,以后可能又出现了占占银行,而这时,ATM

15. 星际争霸之php设计模式--策略模式

题记==============================================================================本php设计模式专辑来源于博客(jymoz.com),现在已经访问不了了,这一系列文章是我找了很久才找到完整的,感谢作者jymoz的辛苦付出哦! 本文地址:http://www.cnblogs.com/davidhhuan/p/4248199.html============================================

PHP设计模式——策略模式

声明:本系列博客参考资料<大话设计模式>,作者程杰. 策略模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换.策略模式让算法独立于使用它的客户而独立变化,即封装变化的算法. 适用场景: 1. 多个类只区别在表现行为不同,可以使用Strategy模式,在运行时动态选择具体要执行的行为. 2. 需要在不同情况下使用不同的策略(算法),或者策略还可能在未来用其它方式来实现. 3. 对客户隐藏具体策略(算法)的实现细节,彼此完全独立. 4.客户端必须知道所有的策略类,并自行决定使

设计模式-策略模式1

* 假设: * 你发现要为一家商店设计一个具有收银打折的软件 * 那么,如何设计才算是最好的呢? * 我们应该考虑到将来的功能的扩充,以及一些商品打折的比例 * * 现在先考虑一下 如何打折? * 比如: 商店的客户只有三种 : 普通用户,白金用户,钻石用户(今后也许还会有VVVIP) * 客户的身份不同折扣也不同 * * 显然,如果写在一个类里面是万万不行的 PS : 单一职责 于是我们很想把每种情况作为一个单独的类.但是为了统一他们的行为,还需要一个公共的方法(可以使用接口或者是抽象类实现)