命令模式
命令模式把一个请求或者操作封装到一个对象中。命令模式把发出命令的责任和执行命令的责任分割开,委派给不同的 对象。命令模式允许请求的一方和发送的一方独立开来,使得请求的一方不必知道接收请求的一方的接口,更不必知道请求是怎么被接收,以 及操作是否执行,何时被执行以及是怎么被执行的。系统支持命令的撤消。
一个对象调用另一个对象的一般过程:
- 创建目标对象的实例
- 设置调用参数
- 调用目标对象的方法
但在有时候我们需要对这种调用过程用类Command加以封装,降低两个对象之间的耦合度。
有一个MM家里管得特别严,没法见面,只好借助于她弟弟在我们俩之间传送信息,她对我有什么指示,就写一张纸条 让她弟弟带给我。这不,她弟弟又传送过来一个COMMAND,为了感谢他,我请他吃了碗杂酱面,哪知道他说:“我同时给我姐姐三个男朋友送 COMMAND,就数你最小气,才请我吃面。”
#include <iostream>
#include <list>
using namespace std;
class Doctor{
public:
void diagnoseEye(){
std::cout << "diagnose eye" << std::endl;
}
void diagnoseNose(){
std::cout << "diagnose nose" << std::endl;
}
};
class Command{
public:
virtual ~Command(){}
virtual void diagnose()=0;
};
class CommandEye : public Command{
public:
CommandEye(Doctor *doc){
this->doc=doc;
}
virtual void diagnose(){
doc->diagnoseEye();
}
private:
Doctor *doc;
};
class CommandNose : public Command{
public:
CommandNose(Doctor *doc){
this->doc = doc;
}
virtual void diagnose(){
doc->diagnoseNose();
}
private:
Doctor *doc;
};
class Nurse{
public:
Nurse(Command *command){
this->command = command;
}
void submitCmd(){
command->diagnose();
}
private:
Command *command;
};
class HeadNurse{
public:
HeadNurse(){
this->m_list.clear();
}
void submitCmd(){
for(list<Command*>::iterator it = m_list.begin(); it!=m_list.end(); it++){
(*it)->diagnose();
}
}
void setCmd(Command *cmd){
m_list.push_back(cmd);
}
private:
list<Command*> m_list;
};
int main()
{
Doctor *doc = new Doctor();
CommandEye *cmdEye = new CommandEye(doc);
CommandNose *cmdNose = new CommandNose(doc);
cmdEye->diagnose();
cmdNose->diagnose();
std::cout << std::endl;
HeadNurse *headNurse = new HeadNurse();
headNurse->setCmd(cmdEye);
headNurse->setCmd(cmdNose);
headNurse->submitCmd();
delete headNurse;
delete cmdNose;
delete cmdEye;
delete doc;
return 0;
}