HeadFirst 设计模式(1)_第1页
HeadFirst 设计模式(1)_第2页
HeadFirst 设计模式(1)_第3页
HeadFirst 设计模式(1)_第4页
HeadFirst 设计模式(1)_第5页
已阅读5页,还剩63页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Design Pattern(设计模式)第一章:Strategy Pattern策略模式Wang Ying-hongTechnical ConsultantHP Technical Service 再增加新鸭? 设计原则1:封装可变性识别程序中可变的特征识别程序中可变的特征, 并将它们与不变的特征分离开来并将它们与不变的特征分离开来GOF:“考虑你的设计中什么可能会发生变化.考虑你允许什么发生变化而不让这一变化导致重新设计” 一种可变性不应散落在代码的很多角落 一种可变性不应当与另一种可变性混合在一起设计原则1:封装可变性识别程序中可变的特征识别程序中可变的特征, 并将它们与不变的特征分离开来

2、并将它们与不变的特征分离开来设计原则1:封装可变性识别程序中可变的特征识别程序中可变的特征, 并将它们与不变的特征分离开来并将它们与不变的特征分离开来 维护,维护, 扩展,扩展, 复用?复用?策略模式的优点 (1)策略模式提供了管理相关的算法族的办策略模式提供了管理相关的算法族的办法。法。 (2)策略模式提供了可以替换继承关系替换继承关系的办法。 (3)使用策略模式可以避免使用多重条件转避免使用多重条件转移语句移语句。策略模式的缺点 (1) 客户端必须知道所有的策略类,并自行决定使用哪一个策略类。 (2)策略模式造成很多的策略类, 增加了对象的数目。 (3)增加了通信开销在什么情况下应当使用策

3、略模式 (1)如果在一个系统里面有许多类,它们之间的区别仅在于它们的行为,那么使用策略模式可以动态地让一个对象在许多行为中选择一种行为。 (2)一个系统需要动态地在几种算法中选择一种。 (3)一个系统的算法使用的数据不可以让客户端知道。 (4)如果一个对象有很多的行为,如果不用恰当的模式,这些行为就只好使用多重的条件选择语句来实现。 策略模式中体现了多个设计原则 设计原则1: 封装变化 面向接口可维护可维护+可扩展可扩展+可复用可复用迪米特逻辑物理一致封装变化依赖倒置里氏法则组合复用封封闭闭开开放放设设 计计 模模 式式 松耦合松耦合 高内聚高内聚.OOP: 封装,继承,多态封装,继承,多态。

4、 设计原则设计原则2:针对接口编程,而非针对实现针对接口编程,而非针对实现 接口使可插入性变得可能。1. Client不必知道其使用对象的具体所属类。2. 一个对象可以很容易地被(实现了相同接口的)的另一个对象所替换。3. 对象间的连接不必硬绑定(hardwire)到一个具体类的对象上,因此增加了灵活性。4. 松散藕合(loosens coupling)。5. 增加了重用的可能性。6. 提高了(对象)组合组合的机率,因为被包含对象可以是任何实现了一个指定接口的类。设计原则设计原则2:针对接口编程,而非针对实现针对接口编程,而非针对实现面向接口可维护可维护+可扩展可扩展+可复用可复用迪米特逻辑物

5、理一致封装变化依赖倒置里氏法则组合复用封封闭闭开开放放设设 计计 模模 式式 松耦合松耦合 高内聚高内聚.OOP: 封装,继承,多态封装,继承,多态。设计原则3: 组合优先组合(has a)比继承(is a)更好一些设计原则3: 组合优先 继承复用 优点 可以很容易的修改或扩展父类的实现设计原则3:组合优先 继承复用的缺点 继承破坏封装,因为父类的实现细节完全暴露给子类(白盒复用) 父类的实现发生改变,则子类必受牵连 继承是静态的,不能在运行时发生改变,不灵活设计原则3:组合优先 组合复用的优点 不破坏封装,这种复用是黑盒复用,因为成员对象的内部细节对新对象保密 所需依赖少(只依赖接口) 可以

6、把成员对象动态替换为另一个类型相同的对象设计原则3:组合优先 组合复用的缺点 对象数量会增加 使用委托(delegation)会使得系统复杂设计原则3:组合优先 例:汽车有很多种,小轿车、货车、客车,有的车是客货两用,有的车水陆两用 如果使用继承来描述: 一旦增加新的汽车种类或用途,都需要大量改动原有代码设计原则3:组合优先 使用“组合”思路考虑问题 “汽车”拥有某种或某些“用途” “汽车”和“用途”独立变化,互不影响面向接口可维护可维护+可扩展可扩展+可复用可复用迪米特逻辑物理一致封装变化依赖倒置里氏法则组合复用封封闭闭开开放放设设 计计 模模 式式 松耦合松耦合 高内聚高内聚.OOP: 封

7、装,继承,多态封装,继承,多态。补充补充 设计原则设计原则4:开:开-闭原则闭原则 “开-闭”原则 Bertrand Meyer: “Software should be open for extension, but closed for modification” 软件应该对扩展开放,软件应该对扩展开放, 对修改关闭对修改关闭 解释 在设计一个软件的时候,应当使这个软件可以在不被修改的前提下扩展 已有模块,尤其是最重要的抽象层模块不能动:保证稳定性和延续性 可以扩展新模块:增加新行为,保证灵活性设计原则4:开-闭原则 Strategy模式对“开-闭”原则的支持设计原则4:开-闭原则 玉帝遵

8、照“开-闭”原则维护天庭秩序 当年孙悟空大闹天空,向天庭发出挑战:“皇帝轮流做,明年到我家.只教他搬出去,将天宫让与我!” 太白金星给玉皇大帝建议道:“降一道招安圣旨,把他宣来上界.与他籍名在箓.一则不动众劳师,二则收仙有道也。”设计原则4:开-闭原则 分析 “不动众劳师”、不破坏天规就是“闭” 收仙有道就是“开” 招安,就是玉帝的“开-闭”原则:既让孙悟空满意,又不必更改天庭现有的秩序设计原则4:开-闭原则 分析 现有的天庭秩序是系统的最高抽象层 弼马温这个职位只是具体的实现层 招安的关键就是不允许更改现有的天庭秩序,但是允许将妖猴纳入到文武百官中,从而扩展了这一秩序的具体实现设计原则4:开-闭原则 Bertrand Meyer 对象技术大师 法国工程院院士 苏黎世工学院计算机系教授 发明了Eiffel语言和按契约设计(Design by Contract)的思想 早年参与了Z形式语言的设计

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论