Command模式

Command模式只是封装了一个没有任何变量的函数.

  • interface Command{ void Excute();}
  • 具有强烈的分解功能的味道.把函数层面的任务提升到了类的层面(一个类仅仅是为了完成一个函数,而且没有该函数外的任何成员).
  • 简单的Command
    • Command模式
    • 事件驱动的系统.
      • Sensor(传感器).驱动者.只负责监听事件,并在事件发生后,调用绑定的Command的Excute方法.而不知道具体绑定的是什么样的Command.
      • Command只负责执行具体的命令逻辑.
      • 两者的绑定关系可以定义于系统主体之外(xml文件etc.)
  • 事务操作.
    • Command模式
    • 解除了 从用户获取数据,验证并操作数据,业务对象本身的耦合关系.
    • 时间上解耦. 立即执行Validate,而把Transaction对放在一个List中,之后再执行.(用于DB中的夜间执行场景).
  • UnDo
    • 给Command接口添加一个Undo方法.
    • 很容易实现:知道如何去excute命令的代码和如何去undo命令的代码几乎类似.
  • Active Object模式
    • Command模式
      public interface CommandEngine
      {
      void AddCommand(Command cmd);
      } public class RTCEngine : CommandEngine
      {
      private List<Command> Commands; public RTCEngine()
      {
      this.Commands = new List<Command>();
      } public void AddCommand(Command cmd)
      {
      this.Commands.Add(cmd);
      } /// <summary>
      /// 执行Command队列中的所有命令,直至队列中不再含有任何的Command.
      /// </summary>
      public void Do()
      {
      while (this.Commands.Count > )
      {
      var cmd = Commands.First();
      this.Commands.Remove(cmd);
      cmd.Excute();
      }
      }
      }
      Command模式
      Command模式
       public interface Command
      {
      void Excute();
      } public class SleepCommand : Command
      {
      private long sleepTime; private CommandEngine engine;
      private Command callBack; private bool start;
      private long startTime; public SleepCommand(long timeout, CommandEngine engine, Command callBack)
      {
      this.sleepTime = timeout;
      this.engine = engine;
      this.callBack = callBack; this.start = false;
      } #region Command Members /// <summary>
      /// 执行,根据条件克隆自己或者添加CallBack命令到Engine中去.
      /// </summary>
      public void Excute()
      {
      long time = System.DateTime.Now.Ticks; //如果还未启动,那么启动自身,同时将自己添加到Engine队列末尾.
      if (!start)
      {
      this.start = true;
      this.startTime = time;
      engine.AddCommand(this);
      }
      //如果还没到唤醒时间,那么添加自己到Engine的队列末尾.
      if (time - startTime < sleepTime)
      {
      engine.AddCommand(this);
      }
      else
      {
      //已经到唤醒时间,将CallBack命令添加到Engine的队列末尾.
      engine.AddCommand(callBack);
      }
      } #endregion
      }
      Command模式
    • 阻塞式多线程:当一个线程等待一个事件时,它通常使用一些OS调用来阻塞自己直到事件发生.
    • RTC(run-to-completion):
      • 每个Command实例都在下一个Command实例可以运行之前就运行完成了.
      • 意味着Command实例不会阻塞.(如果等待的事件未到来,只是把自己放回到Engine中).
      • Command实例一经运行就一定得完成.所有的Command实例可以共享一个运行时堆栈.(减少内存使用量).

总结. Command模式具有极其的简洁性.但可以用于DB的Transaction操作,设备控制,多线程核心,GUI的do/undo管理.

其有不符合OO范式的味道.对函数的关注超过了类.

[Agile Software Development(Principles,Patterns,and Pracitices)]

上一篇:20145308刘昊阳 《Java程序设计》第4周学习总结


下一篇:.Net程序员之不学Java做安卓开发:Android Studio中的即时调试窗口