命令模式和状态模式的理解

原创 2007年10月06日 15:38:00
 命令模式的理解,关键有2点:
一、使用接口---实现类的方式。
  通常命令模式的接口中只有一个方法。
    实现类的方法有不同的功能,覆盖接口中的方法。
    在面向对象编程中,大量使用if…else…,或者switch…case…这样的条件选择语句是“最差实践”。通常这类代码,意味着有重构的余地。
命令模式就是干掉条件选择语句的利器。
1,首先提供一个接口:
public interface Command {
public void execute();
}
 
2,然后提供这个接口的实现类。每一个实现类的方法就是if…else…的一个代码块中的代码。
这样,调用方直接把一个具体类的实例传进来即可。如:
Public void test(Command para){
   Para.execute();
 
}
    即可,不需要再判断出现了哪种情况,应该执行哪一段代码。
一切的问题都由调用方处理。
如果不使用命令模式,那么如果情况逐步增多,如,从原来的2种,增加到20种,那么方法中的判断就会从1次增加到19次。
而使用命令模式,仅仅调用方需要从2个实现类增加到20个实现类即可。上面的test方法根本不需要做任何改变。
 
二、主要的用途是,使用参数回调模式。
  最主要使用命令模式的方式是使用参数回调模式。
命令接口作为方法的参数传递进来。然后,在方法体内回调该接口。
上文的例子是如此,Swing的事件机制也是使用这种方法。
如:
public interface Command {
public void execute();
}
 
public void actionPerformed(ActionEvent e) {
Command cmd = (Command)e.getSource();
cmd.execute();
}
 
当然,命令模式还可以使用其他方式来使用。不一定非用参数回调模式。
命令模式的核心思想是,带有某个方法的具体类的实例,作为接口传给使用方。对象的具体类型信息消失。
在使用方代码中拿到这个接口后调用这个接口的方法。
具体的执行效果,取决的命令发起人提供的对象是哪一个实现类的。这给了命令发起人完全的控制能力,而使用方代码不关心具体的命令类和方法。同时也使条件判断语句成为多余。
简单吗?命令模式其实就是这么简单。
状态模式的理解
状态state模式是GOF23种模式中的一种,和命令模式一样,也是一种行为模式。
状态模式和命令模式相当像,一样是“接口—实现类”这种模式的应用,是面向接口编程原则的体现。
 
状态模式的理解,关键有2点:
一、使用接口---实现类的方式。
  通常命令模式的接口中只有一个方法。
 而状态模式的接口中有1个或者多个方法。
1,而且,状态模式的实现类的方法,一般返回值;或者是改变实例变量的值。
    也就是说,状态模式一般和对象的状态有关。
2,实现类的方法有不同的功能,覆盖接口中的方法。
3,状态模式和命令模式一样,也可以用于消除if…else等条件选择语句。
 
二、主要的用途是,作为实例变量,是一个对象引用。
  1,命令模式的主要的使用方式是参数回调模式。
命令接口作为方法的参数传递进来。然后,在方法体内回调该接口。
   2,而状态模式的主要使用方法,是作为实例变量,通过set属性方法,或者构造器把状态接口的具体实现类的实例传递进来。
 
因此,可以这样比较命令模式和状态模式的异同:
一、相同点
都是面向接口编程原则的体现。都使用了“接口—实现类”模式。、
二、不同点
1,命令模式,常常意味着使用它们的类使用的是单例模式,也就是服务类,只有提供服务的方法,没有实例变量的类。
可以使用一个对象为所有用户服务,占用内存少。
2,状态模式,其接口的实现类,一般有状态,也就是实例变量。如果没有实例变量,方法就一定会有返回值,返回状态给用户。
使用它们的类,一般把它们作为实例变量保存起来。这样,就意味着,使用它们的类不能使用单例模式,需要保存状态。每一个请求,都需要创建一个新的对象为其服务。
单例模式,典型的应用就是stateless session bean 无状态会话bean;
多例模式,典型的应用就是stateful session bean 有状态会话bean。
 
下面看state模式的例子:
//state接口
public interface State {
//得到状态
public void getState();
//改变状态
public void setStateA();
public void setStateB();
 
}
//state实现类
Public class StateA{
 String state;
 ……
 
 
}
//state的使用类
Public class Context{
   Private State state;
   Public void setState(State state){
 
}
 
 setStateA(){
……
   State.setStateA();
……
}
……
 
}
 
如果Context使用单例模式,那么实例变量的值state就不能够保证是单独使用的。
State模式和command模式都是十分常用,粒度比较小的模式,是很多更大型模式的一部分。
基本上,state模式和command模式是十分相似的。只要开发者心中对单例和多例有一个清醒的认识,即使不把它们分为两种模式也没事。
摘自:良少专栏的专栏】 

三分钟理解“状态模式”——设计模式轻松掌握

什么是状态模式? 一个函数原本有很多判断语句,现在把判断语句中的每一种状态封装成一个类,每一个状态类中均有一个handle()函数,该函数能对当前状态做出处理,并且能指明不能处理时的下一个状态类。 ...
  • u010425776
  • u010425776
  • 2015年09月06日 16:00
  • 683

命令模式,状态模式和职责链模式的不同

命令模式:将多个命令只提交给一个执行该命令的对象 而职责链模式相反:只将一个请求提交给多个能执行该命令的对象 状态模式与职责链模式的区别: 状态模式是让各个状态对象自己知道其下一个处理的对象...
  • u010585135
  • u010585135
  • 2015年07月06日 21:36
  • 686

设计模式之策略模式与状态模式的区别

转策略模式与状态模式的比较状态模式(state pattern)和策略模式(strategy pattern)的实现方法非常类似,都是利用多态把一些操作分配到一组相关的简单的类中,因此很多人认为这两种...
  • u011040361
  • u011040361
  • 2015年04月19日 17:46
  • 846

设计模式 状态模式 策略模式 观察者模式 命令模式 中介者模式

设计模式(对象行为型) 一.状态模式 环境类(Context):  定义客户感兴趣的接口。维护一个ConcreteState子类的实例,这个实例定义当前状态。 抽象状态类(State):...
  • ky_heart
  • ky_heart
  • 2017年05月18日 10:38
  • 325

设计模式——状态模式详解

0. 前言写在最前面,本人的设计模式类博文,建议先看博文前半部分的理论介绍,再看后半部分的实例分析,最后再返回来复习一遍理论介绍,这时候你就会发现我在重点处标红的用心,对于帮助你理解设计模式有奇效哦~...
  • SEU_Calvin
  • SEU_Calvin
  • 2016年10月12日 14:11
  • 9467

状态模式 VS 职责链模式

这次合作开发过程中我们使用了一些设计模式,经过讨论对其理解深刻不少。之前在学习之中,我本以为自己已经理解了一些设计模式。但在这次的使用过程中,因为各自的理解不一造成了一定的碰撞,之后才发现自己的理解根...
  • zhuojiajin
  • zhuojiajin
  • 2013年12月05日 11:09
  • 2563

状态模式和策略模式比较

说到策略模式,我们最先想到的就是商店的收银方式:不满100,正常收费;超过100不满300,超过的部分打八折;超过300,全价九折!      解决这个问题最最普通的方法就是大量的If…Else…,而...
  • u010191243
  • u010191243
  • 2015年04月30日 16:37
  • 2468

状态模式和策略模式的区别

区别主要体现在行为上,而不是结构上,所以,看时序图就能很好的看出两者的区别。状态是系统自身的固有的,调用者不能控制系统的状态转移。策略是外界给的,策略怎么变,是调用者考虑的事情,系统只是根据所给的策略...
  • ruangong1203
  • ruangong1203
  • 2016年09月12日 16:54
  • 1360

状态模式与职责链模式

在学习设计模式的时候发现状态模式与职责链模式特别的相似,当时没有能理解,现在回过头来看了看,查 了查资料,明白了一点,先把自己的理解写下来,在以后的学习继续深入学习 一、状态模式 ...
  • u012704843
  • u012704843
  • 2015年03月29日 20:46
  • 1334

对命令模式的理解

乍看起来,命令模式有点复杂,但其实细分起来,有点像是对模板模式中父类在一个统一的类中进行了一个封装。 模板方法的使用场景主要是提供了对多态的一个统一访问入口。并且根据入口对象的命令对象,来执行命令。 ...
  • wujiang88
  • wujiang88
  • 2016年01月23日 16:45
  • 193
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:命令模式和状态模式的理解
举报原因:
原因补充:

(最多只允许输入30个字)