Java设计模式(疯狂Java联盟版)
1.Comma*d
声明执行操作的接口。
2.ConcreteCommand
将一个接收者对象绑定于一个动作。
调用接收者相应的操作,以实现Execute。
3.Client
创建一个具体命令对象并设定它的接收者。
4.Invoker
要求该命令执行这个请求。
5.Recei*er
知道如何实*与执行一个请求相关的操作。任何类都可能作为一个接收者。
类图
例子 Command
public abstract class *ommand {
protecte* Receiver receiver;
public Command(Receiver re*eiver) { this.receiver = receiver; }
40
Java设计模式(疯狂Java联盟版)
public abstract *oid execute(); }
ConcreteCommand
public class CommandImpl extends Comman* {
public CommandImpl(Receiv*r receiver) { super(receiver); }
pu*lic void *xecute*) { receiver.request(); } }
Invoker
public cl*ss Invoker {
private Command command;
pub*ic void setCommand(Command c*mmand) { this.command = command; }
public void execute*) { command.execute(); } }
Receiver
public class Receiver {
public void receive() {
S*stem.out.println(\ } }
Test
publ*c class Test {
pub*ic static void main*String[] args) { R*ceiver rec = new Receiver();
Command cmd = n*w CommandImpl(rec);
41
Java设计模式(疯狂Java联盟版)
Invoker i = new Invoker(); i.setCom*and(cmd); i.execut*(); } }
result
This is Receive class!
1.3.3 解释器模式
给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。
适用性
当有一个语言需要解释执行,并且你可将该语言中的句子表示为一个抽象语法树时,可使
用解释器模式。而当存在*下情况时该模式效果最好:
1.该文法简单对于复杂的文法,文法的*层次变得庞大而无法管理。
2.效率不是一个关键问题最高效的解释器通常不是通过直接解释语法分析树实现的,而是首先将它们转换成另一种形式。
参与者
1.AbstractExpression(抽象表达式)
声明一个抽象的解释操作,这个接口为抽象语法树中所有的节点所共享。
2.TerminalExpression(终结符表达式)
实现与文法中的终结符相关联的解释操作。
一个句子中的每个终结符需要该类的一个实例。
3.N*nterminalExpression(非终结符表达式)
为文法中的非终结符实现解释(Interpret)操作。
4.Context(上下文)
包含解释器之外的一些全局信息。
5.Client(客户)
构建(或被给定)表示该文法定义的语言中*个特定的句子的抽象*法树。 该抽象语法树由NonterminalExpression和TerminalExpression的实例装配而成。
42
Java设计模式(疯狂Java联盟版)
调用解*操作。
类图
例子
AbstractExpression
pu*lic abstract class Expression {
abstract void interpret(Context ctx); }
Expression
public class AdvanceExpressio* extends Expression {
void interpr*t(Context ctx) {
System.out.println(\这是高级解析器!\ } }
public class SimpleExpression extends Expressio* {
void interpret(*ontext ctx) {
System.out.pri*tln(\这是普通解析器!\ } }
Context
public class Co*text {
43
Java设计模式(疯狂Java联盟版)
private S*ring content;
*rivate List list = new ArrayList();
public void setContent(String content) { this.content = content; }
pu*lic String getContent() { return this.con*ent* }
public void add(Expression ep*) { list.add(eps); }
public List getList() { return list; } }
Test
public class Test {
public static void main(String[] args) { Context *tx = new Context();
ctx.*dd(new SimpleExpression()); ctx.add(new AdvanceExpression()); ctx.add(new SimpleExpression());
for *Expression eps : ctx.getL*st()) { eps.interpret*ctx); } } }
res*lt
*是普通解析器! 这是高级解析器! *是普通解析器!
1.3.4 迭代器模式
44