⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 client.java

📁 设计模式描述设计模式描述设计模式描述设计模式描述
💻 JAVA
字号:
/*
 * Created on 2005-5-11
 *
 * TODO To change the template for this generated file go to
 * Window - Preferences - Java - Code Style - Code Templates
 */
package com.test.pattern.behavir.command;

/**
 * @author Administrator
 * 
 * 意图 将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化;对请求排队或记录请求日志,以及支持可撤消的操作。 适用性
 * 抽象出待执行的动作以参数化某对象,你可用过程语言中的回调(c a l l b a c k
 * )函数表达这种参数化机制。所谓回调函数是指函数先在某处注册,而它将在稍后某个需要的时候被调用。C o m m a n d
 * 模式是回调机制的一个面向对象的替代品。 在不同的时刻指定、排列和执行请求。一个C o m m a n d
 * 对象可以有一个与初始请求无关的生存期。如果一个请求的接收者可用一种与地址空间无关的方式表达,那么就可将负责该请求的命令对象传送给另一个不同的进程并在那儿实现该请求。
 * 支持取消操作。C o m m a n d 的E x c u t e 操作可在实施操作前将状态存储起来,在取消操作时这个状态用来消除该操作的影响。C o m
 * m a n d 接口必须添加一个U n e x e c u t e 操作,该操作取消上一次E x e c u t e
 * 调用的效果。执行的命令被存储在一个历史列表中。可通过向后和向前遍历这一列表并分别调用U n e x e c u t e 和E x e c u t e
 * 来实现重数不限的“取消”和“重做”。 支持修改日志,这样当系统崩溃时,这些修改可以被重做一遍。在C o m m a n d
 * 接口中添加装载操作和存储操作,可以用来保持变动的一个一致的修改日志。从崩溃中恢复的过程包括从磁盘中重新读入记录下来的命令并用E x e c u t e
 * 操作重新执行它们。 用构建在原语操作上的高层操作构造一个系统。这样一种结构在支持事务( t r a n s a c t i o n
 * )的信息系统中很常见。一个事务封装了对数据的一组变动。C o m m a n d 模式提供了对事务进行建模的方法。C o m m a n d
 * 有一个公共的接口,使得你可以用同一种方式调用所有的事务。同时使用该模式也易于添加新事务以扩展系统。
 *  
 */
abstract class Command {
	abstract public void Execute();

	protected Receiver r;

	public void setR(Receiver value) {
		r = value;
	}
}

class ConcreteCommand extends Command {
	public void Execute() {
		System.out.println("Command executed");
		r.InformAboutCommand();
	}
}

class Receiver {
	public void InformAboutCommand() {
		System.out.println("Receiver informed about command");
	}

}

class Invoker {
	private Command command;

	public void StoreCommand(Command c) {
		command = c;
	}

	public void ExecuteCommand() {
		command.Execute();
	}
}

/// <summary>
/// Summary description for Client.
/// </summary>

public class Client {
	public static void main(String[] args) {
		// Set up everything
		Command c = new ConcreteCommand();
		Receiver r = new Receiver();
		c.setR(r);
		Invoker i = new Invoker();
		i.StoreCommand(c);

		// now let application run

		// the invoker is how the command is exposed for the end-user
		// (or a client) initiates the command,
		// (e.g. toolbar button, menu item)

		i.ExecuteCommand();

	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -