解释器模式
给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子
适用性
当有一个语言需要解释执行,并且你可以将该语言中的句子表示为一个抽象语法树时,可以使用解释器模式。而当存在以下情况时,该模式效果最好
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.http://www.cnblogs.com/java-my-life/archive/2012/06/19/2552617.html