设计模式的基本思想:面向接口编程是核心。
命令模式的设计主要是是为了完成请求调用者与请求接收者之间进行解耦。
命令模式将“请求”封装成对象,以便使用不同的请求、队列或者日志来参数化其他对象。通过使用命令模式屏蔽掉命令接收者的任务的具体实现(要做的事情),从而做到命令的请求调用者不必知道命令接收的具体实现从而达到两者解耦的目的。提供命名相关接口(方法)的通用性。
命令模式的UML图如下:
Client负责创建一个具体的ConcreteCommand命令,同时给此命令设置一个命令接收者。
invoker负责在调用者持有一个命令对象,并在某时刻调用命令对象的具体执行方法。
Command是一个命令接口,调用命令对象的execute()方法,就可以让接收者进行相关的动作。
Raceiver作为命令的接收者来完成具体的操作。
具体实现如下:
package CommandModel;
public interface Command {
void execute();
}
———————————————————————
package CommandModel;
public class Light {
public void on(){
System.out.println("我是灯,我接受到了开灯的命令,打开了灯!");
}
}
———————————————————————
package CommandModel;
public class LightCommand implements Command {
private Light light;
public LightCommand(Light light){
this.light = light;
}
@Override
public void execute() {
// TODO Auto-generated method stub
light.on();
}
}
———————————————————————
package CommandModel;
public class RemoteControlTest {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
SimpleRemoteContral src = new SimpleRemoteContral();
Light light = new Light();
//将灯与控制灯的命令进行绑定
LightCommand lightComm = new LightCommand(light);
//调用命令控制类对象来控制命令的执行
src.setCommand(lightComm);
//执行命令
src.startExecute();
}
}
———————————————————————
package CommandModel;
public class SimpleRemoteContral {
private Command slot;
//设置命令对象
public void setCommand(Command comm){
this.slot = comm;
}
//这行命令方法
public void startExecute(){
if(slot != null){
slot.execute();
}
}
}
使用了观察者模式和命令模式,那么两者有什么区别呢?