Command – 命令模式

Command – 命令模式

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

定义

将一个请求封装为一个对象,实现请求者与实施者的低耦合。

案例
大部分应用都存在非常多的菜单和一些操作button,但在设计这些菜单和button的时候,并不知道它要运行什么样的操作。在设计删除、复制和撤销这些详细实现的时候,也不知道在要什么地方用到,可能是代码里面直接调用,也可能是界面上点击了某个button后发生的操作。为了解决菜单和详细操作的这样的耦合度,就须要使用Command-命令模式:
Command - 命令模式

Command - 命令模式

菜单类的每个Item都保存一个Command子类的对象实例,当界面点击的时候,就调用Command的execute()方法,在Command子类的execute()方法里面会直接调用Receiver的action()方法,就运行详细的操作。
   
   
  1. class MenuItem {
  2. public:
  3. void setCommand(Command* comand) { m_command = command; }
  4. void onClicked() {
  5. m_command->execute();
  6. }
  7. private:
  8. Command* command;
  9. }
  10. class Command {
  11. public:
  12. virtual void execute();
  13. virtual bool isEnable();
  14. };
  15. class CopyCommand {
  16. public:
  17. virtual void execute() {
  18. m_receiver->action();
  19. }
  20. private:
  21. CopyReceiver* m_receiver;
  22. };
  23. class DeleteCommand {
  24. public:
  25. virtual void execute() {
  26. m_enable = m_receiver->action();
  27. }
  28. bool isEnable() {
  29. return m_enable;
  30. }
  31. private:
  32. DeleteReceiver* m_receiver;
  33. bool m_enable;
  34. };

一个Command对象还能够被不同的Invoker对象保存,用以实现相同的操作:
    
    
  1. MenuItem* copyItem = new MenuItem("Copy");
  2. MenuItem* deleteItem = new MenuItem("Delete");
  3. MenuItem* undoItem = new MenuItem("Undo");
  4. Button* copyButton = new Button("Copy");
  5. Button* deleteButton = new Button("Delete");
  6. Button* undoButton = new Button("Undo");
  7. Command* copyCommand = new CopyCommand();
  8. Command* deleteCommand = new DeleteCommand();
  9. Command* undoCommand = new UndoCommand();
  10. copyItem->setCommand(copyCommand);
  11. deleteItem->setCommand(deleteCommand);
  12. undoItem->setCommand(undoCommand);
  13. copyButton->setCommand(copyCommand);
  14. deleteButton->setCommand(deleteCommand);
  15. undoButton->setCommand(undoCommand);

Command - 命令模式

Command - 命令模式

同样的操作都使用同一个对象,当undoCommond的enable()返回false的时候,菜单和button都不能使用了。

适用性
  • 抽象出待运行的操作以參数化某对象,Command模式就像一个回调函数的对象实现。
  • 在不同的时刻指定、排列和运行请求,Commad有一个与初始请求无关的生存期。
  • 能够支持取消操作,在Command对象运行execute方法的之前把信息保存,提供一个unExecute方法恢复在运行前。也能够使用一个专门的Command来保存全部运行了的Commond对象比方UndoCommand来达到回滚操作。
  • 支持事物(Transaction),对一系列数据进行提交操作。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118161.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 在centos7上安装夜莺监控

    在centos7上安装夜莺监控所需包(仅作参考)在/opt目录下建立目录/n9e和/temp安装包存放在/opt/temp目录下mysql-5.7.31-linux-glibc2.12-x86_64.7znginx-1.14.2.7zp7zip-16.02-10.el7.x86_64.rpmredis-6.0.6.7zn9e-2.7.2.7z1.安装7zrpm-ivhp7zip-16.02-10.el7.x86_64.rpmyum-yinstallepel-releaseyum-yi

    2022年5月30日
    54
  • verilog序列生成器最少移位寄存器实现[通俗易懂]

    verilog序列生成器最少移位寄存器实现[通俗易懂]verilog序列生成器最少移位寄存器实现序列生成器序列生成器实现方式移位寄存器版(输入序列版)最少移位寄存器版VCS仿真![仿真](https://img-blog.csdnimg.cn/42e1e4f55f4443faa70b38adad7c5db1.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBASmFydmlz56CB5ZGY,size_20,color_FFFFFF,t_7

    2022年7月16日
    16
  • smartselect是什么意思_Smart Connect

    smartselect是什么意思_Smart Connect一、什么是S.M.A.R.T.SMART是一种磁盘自我分析检测技术,早在90年代末就基本得到了普及每一块硬盘(包括IDE、SCSI)在运行的时候,都会将自身的若干参数记录下来这些参数包括型号、容量、温度、密度、扇区、寻道时间、传输、误码率等硬盘运行了几千小时后,很多内在的物理参数都会发生变化某一参数超过报警阈值,则说明硬盘接近损坏此时硬盘依然在工作,如果用户不理睬这个报警继续

    2022年10月8日
    1
  • 用一份JAVA工程师的求职简历来说说求职简历怎么写[通俗易懂]

    用一份JAVA工程师的求职简历来说说求职简历怎么写[通俗易懂]这是一篇我比较想看到的简历指导的文章。但是我比较反对简历造假。我觉得会什么写什么把。Java就业指导  想要成为合格的Java程序员或工程师到底需要具备哪些专业技能,面试者在面试之前到底需要准备哪些东西呢?本文陈列的这些内容既可以作为个人简历中的内容,也可以作为面试的时候跟面试官聊的东西,你可以把这些内容写到你的简历中,当然更需要的是你在面试的时候向面试官展示这些专业技能。相信此文…

    2022年9月23日
    2
  • 汇编指令周期_微指令周期

    汇编指令周期_微指令周期MnemonicByteCycADDA,@Ri11ADDA,Rn11ADDA,direct21ADDA,#data21ADDCA,@Ri11ADDCA,Rn11

    2022年10月9日
    3
  • 解决bad SQL grammar []; nested exception is java.sql.SQLSyntaxErrorException: ORA-00911: 无效字符

    解决bad SQL grammar []; nested exception is java.sql.SQLSyntaxErrorException: ORA-00911: 无效字符1.报错:###Cause:java.sql.SQLSyntaxErrorException:ORA-00911:无效字符;badSQLgrammar[];nestedexceptionisjava.sql.SQLSyntaxErrorException:ORA-00911:无效字符2.出错原因:1)sql在数据库执行都是OK的。真…

    2025年6月1日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号