JAVA 设计模式 命令模式

用途

命令模式 (Command)

将一个请求封装为一个对象,从而使你可以用不同的请求对客户进行参数化; 对请求排队或请求日志,以及支持可撤销的操作。

命令模式是一种行为型模式

结构

图-命令模式结构图

Command : 用来声明执行操作的接口。

abstract class Command {
 protected Receiver receiver;
 public Command(Receiver receiver) {
 this.receiver = receiver;
     }
 
 public abstract void Execute();
 }

ConcreteCommand : 将一个接收者对象绑定一个动作,调用接收者相应的操作,以实现Execute。

class ConcreteCommand extends Command {
 public ConcreteCommand(Receiver receiver) {
 super(receiver);
     }
 
     @Override
 public void Execute() {
         receiver.Action();
     }
 }

Invoker : 要求该命令执行这个请求。

class Invoker {
 private Command command;
 
 public Invoker(Command command) {
 this.command = command;
     }
 
 public void ExecuteCommand() {
         command.Execute();
     }
 }

Receiver : 知道如何实施与执行一个与请求相关的操作,任何类都可能作为一个接收者。

class Receiver {
 public void Action() {
         System.out.println("执行请求");
     }
 }

Client : 创建一个具体命令对象并设定它的接受者。

public class CommandPattern {
 public static void main(String[] args) {
         Receiver receiver = new Receiver();
         Command cmd = new ConcreteCommand(receiver);
         Invoker invoker = new Invoker(cmd);
         invoker.ExecuteCommand();
     }
 }

交互

图-命令模式交互图

1、Client 创建一个 ConcreteCommand 对象并指定他的 Receiver 对象。 2、某个 Invoker 对象存储该 ConcreteCommand 对象。 3、该 Invoker 通过调用 Command 对象的 Execute 操作来提交一个请求。若该命令是可撤销的,ConcreteCommand 就在执行 Execute 操作之前存储当前状态以用于取消该命令。 4、ConcreteCommand 对象对调用它的 Receiver 的一些操作以执行该请求。

要点

1、命令模式的本质是对命令进行封装,将发出命令的责任和执行命令的责任分割开。 2、每一个命令都是一个操作:请求的一方发出请求,要求执行一个操作;接收的一方收到请求,并执行操作。 3、命令模式允许请求的一方和接收的一方独立开来,使得请求的一方不必知道接收请求的一方的接口,更不必知道请求是怎么被接收,以及操作是否被执行、何时被执行,以及是怎么被执行的。 4、命令模式使请求本身成为一个对象,这个对象和其他对象一样可以被存储和传递。 5、命令模式的关键在于引入了抽象命令接口,且发送者针对抽象命令接口编程,只有实现了抽象命令接口的具体命令才能与接收者相关联。

推荐

本文属于 JAVA设计模式系列

参考资料

《大话设计模式》《HeadFirst设计模式》

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏xingoo, 一个梦想做发明家的程序员

大数据之Yarn——Capacity调度器概念以及配置

试想一下,你现在所在的公司有一个hadoop的集群。但是A项目组经常做一些定时的BI报表,B项目组则经常使用一些软件做一些临时需求。那么他们肯定会遇到同时提交...

2459
来自专栏C/C++基础

操作系统简介

操作系统(Operating System,OS)是计算机系统组成要素,是管理和控制计算机硬件与软件资源的基本软件。操作系统是用户和计算机交互的接口,也是计算机...

853
来自专栏性能与架构

linux查看CPU和内存的使用情况

image.png CPU使用情况 通常使用top命令查看CPU的当前状态,如果是多核CPU,也可以看到每核的信息 # top 执行后按数字1,可以显示多个CP...

3337
来自专栏情情说

RabbitMQ实战:性能和安全

前两篇介绍了RabbitMQ在可用性、监控方面的考虑,这是基础保障,因为在某些场景下是不容许丢失消息的,但它和性能往往是对立的,需要根据业务场景做取舍。

5988
来自专栏无题

mongoDB常见问题整理

多方收集整理成此篇,以后也会持续更新。 为什么要使用Nosql 关系型数据库采用的结构化的数据,NoSQL采用的是键值对的方式存储数据。 mongo使用场景: ...

3534
来自专栏存储

spring boot redis分布式锁

随着现在分布式架构越来越盛行,在很多场景下需要使用到分布式锁。分布式锁的实现有很多种,比如基于数据库、zookeeper等,本文主要介绍使用Redis做分布式锁...

4225
来自专栏向治洪

基于XMPP协议的Android即时通信系

设计基于开源的XMPP即时通信协议,采用C/S体系结构,通过GPRS无线网络用TCP协议连接到服务器,以架设开源的Openfn'e服务器作为即时通讯平台。  ...

20510
来自专栏大数据和云计算技术

HBASE+Solr实现详单查询

最近群里面讨论HBASE的使用场景,以及是会没落,这个还真是一句话说不清楚。本文讲其中一个场景:详单查询。 背景 某电信项目中采用HBase来存储用户终端明细数...

3515
来自专栏码匠的流水账

缓存的Cache Aside模式

1083
来自专栏芋道源码1024

分布式作业 Elastic-Job-Lite 源码分析 —— 主节点选举

无中心化,意味着 Elastic-Job-Lite 不存在一个中心执行一些操作,例如:分配作业分片项。Elastic-Job-Lite 选举主节点,通过主节点进...

792

扫码关注云+社区