状态模式和策略模式的比较
状态模式(state pattern)和策略模式(strategy pattern) 的实现方法非常类似,都是利用多态把一些操作分配到一组相关的简单的类中,因此很多人认为这两种模式实际上是相同的。
然而在现实世界中,策略(如促销一种商品的策略)和状态(如同一个按钮来控制一个电梯的状态,又如手机界面中一个按钮来控制手机)是两种完全不同的思想。当我们对状态和策略进行建模时,这种差异会导致完全不同的问题。例如,对状态进行建模时,状态迁移是一个核心内容;然而,在选择策略时,迁移与此毫无关系。另外,策略模式允许一个客户选择或提供一种策略,而这种思想在状态模式中完全没有。
一个策略是一个计划或方案,通过执行这个计划或方案,我们可以在给定的输入条件下达到一个特定的目标。策略是一组方案,他们可以相互替换;选择一个策略,获得策略的输出。策略模式用于随不同外部环境采取不同行为的场合。我们可以参考微软企业库底层Object Builder的创建对象的strategy实现方式。
而状态模式不同,对一个状态特别重要的对象,通过状态机来建模一个对象的状态;状态模式处理的核心问题是状态的迁移,因为在对象存在很多状态情况下,对各个business flow,各个状态之间跳转和迁移过程都是及其复杂的。例如一个工作流,审批一个文件,存在新建、提交、已修改、HR部门审批中、老板审批中、HR审批失败、老板审批失败等状态,涉及多个角色交互,涉及很多事件,这种情况下用状态模式(状态机)来建模更加合适;把各个状态和相应的实现步骤封装成一组简单的继承自一个接口或抽象类的类,通过另外的一个Context来操作他们之间的自动状态变换,通过event来自动实现各个状态之间的跳转。在整个生命周期中存在一个状态的迁移曲线,这个迁移曲线对客户是透明的。我们可以参考微软最新的WWF 状态机工作流实现思想。
在状态模式中,状态的变迁是由对象的内部条件决定,外界只需关心其接口,不必关心其状态对象的创建和转化;而策略模式里,采取何种策略由外部条件(C)决定。
via 状态模式和策略模式的比较 - My Space - JavaEye技术网站.
建议继续学习:
- 软件架构模式的种类 (阅读:2875)
- 让生活变简单的简单网站 (阅读:2267)
- JavaScript Dynamic Prototype Pattern (阅读:1783)
- 关于经营模式 (阅读:1653)
- JavaScript Creating Objects Other Pattern (阅读:1627)
- 聊聊设计模式(4):装饰模式 (阅读:1606)
- Python创建单例模式的三种方式 (阅读:1657)
- 一个状态模式的小改进 (阅读:1239)
- 一个状态模式的小改进 (阅读:1221)
- [译]Go开发中一些有用的模式 (阅读:1209)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:IDEAL Garden 来源: IDEAL Garden
- 标签: 模式 状态模式 策略模式
- 发布时间:2010-07-21 23:03:57
- [47] WEB系统需要关注的一些点
- [47] Oracle MTS模式下 进程地址与会话信
- [45] android 开发入门
- [45] 【社会化设计】自我(self)部分――欢迎区
- [45] Go Reflect 性能
- [45] IOS安全–浅谈关于IOS加固的几种方法
- [44] Twitter/微博客的学习摘要
- [42] 图书馆的世界纪录
- [42] 关于恐惧的自白
- [42] find命令的一点注意事项