您的位置:首页 > 编程语言 > Java开发

设计模式(十五)----- 解释器模式(Interpreter)----(JAVA版)

2013-01-09 19:42 627 查看

解释器模式

给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子

适用性

当有一个语言需要解释执行,并且你可以将该语言中的句子表示为一个抽象语法树时,可以使用解释器模式。而当存在以下情况时,该模式效果最好

1.该文法简单对于复杂的文法,文法的层次变得庞大而无法管理

2.效率不是一个关键问题。最高效的解释器通常不是通过直接解释语法分析树实现的,而是首先将它们转换成另一种形式

参与者

1.AbstractExpression(抽象表达式)

声明一个抽象的解释操作,这个接口为抽象语法树中所有的节点所共享

2.TerminalExpression(终结符表达式)

实现与文法中的终结符相关联的解释操作。一个句子中的每个终结符需要该类的一个实例

3.NonterminalExpression(非终结符表达式)

为文法中的非终结符实现解释(Interpret)操作

4.Context(上下文)

包含解释器之外的一些全局信息

5.Client

构建(或被给定)表示该文法定义的语言中一个特定的句子的抽象文法树。该抽象语法树由TerminalExpression和NonterminalExpression的实例装配而成

一个例子

1.AbstractExpression

public interface Expression {
void interpret(Context c);
}


2.Expression

public class SimpleExpression implements Expression {

@Override
public void interpret(Context c) {
System.out.println("这是简单解释器。。。");
}
}


public class AdvanceExpression implements Expression {

@Override
public void interpret(Context c) {
System.out.println("这是先进解释器。。。");
}
}


3.Context

public class Context {
private String content;
private List<Expression> list = new ArrayList<Expression>();

public String getContent() {
return content;
}

public void setContent(String content) {
this.content = content;
}

public List<Expression> getList() {
return list;
}

public void add(Expression e) {
list.add(e);
}
}


4.test

public class Test {
public static void main(String[] args) {
Context c = new Context();
c.add(new SimpleExpression());
c.add(new AdvanceExpression());
c.add(new SimpleExpression());
for (Expression eps : c.getList()) {
eps.interpret(c);
}
}
}


result

这是简单解释器。。。

这是先进解释器。。。

这是简单解释器。。。

参与文献:

1.http://rainbowj234.diandian.com/post/2011-11-20/6967684

2./article/5110149.html

3./article/4497443.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: