Java设计模式(疯狂Java联盟版)
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的实例装配而成。
调用解*操作。
类图
41
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 {
private S*ring content;
42
Java设计模式(疯狂Java联盟版)
*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 迭代器模式
给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。
43
Java设计模式(疯狂Java联盟版)
适用性
1.访问一个聚合对象的内容而无需暴露它的内部表示。
2.支持对聚合对象的多种遍历。
3.为遍历不同的聚合结构提供一*统一的接口(即,支持多态迭代)。
参与者
1.Iterator
迭代器定义访问和遍历元素的接口。
2.ConcreteIterator
具*迭代器实现迭代器接口。 对该聚合遍历时跟踪当前位置。
3.Aggregate
聚合定义创建相应迭代器*象的接口。
4.ConcreteAggregate
具体聚合实现创建相应迭代器的接口,该操作返回ConcreteIterator的一个适当的实例.
类图
例子 Iterator
public interface Iterator {
Object nex*();
44
Java设计模式(疯狂Java联盟版)
void first();
voi* last();
boolean hasNext(); }
ConcreteIterator
public class IteratorImpl implements It*rator {
private List list;
private int index;
public Ite*atorImpl(List list* { index = 0;
this.list = list; }
public void first() { index = 0; }
publ*c void last() {
index = list.getSize(); }
public Object next() {
Object obj = list.get(index); index++; ret*rn obj; }
public boolean hasNext() {
return index < list.getSize(); } }
Aggregate
p*blic interface List {
Iterator iterator();
45