一。概述
给定一个语言,定义它的文法的一种表示,并表示一个解析器,这个解析器使用该表示来解释语言中的句子。
二。适用性
当有一个语言需要解释执行,并且你可将语言中的句子表示为一个抽象语法树时,可使用解释器模式。而当存在一下情况时该模式效果最好:
1.该文法简单对于复杂的文法,文法的类层次变得庞大而无法管理。
2.效率不是一个关键问题最高效的解析器通常不是通过直接解释语法分析树实现的,而是首先将它们转换成另一种形式。
三。参与者。
1.AbstractExpression声明一个抽象的解释操作,这个接口为抽象语法中所有的节点所共享。
2.TerminalExpression实现与文法中的终结符相关的解释操作。一个句子中的每个终结符需要该类的一个实例。
3.NonterminalExpression为文法中的非终结符实现解释Interpret操作。
4.Context包含解析器之外的一些全局信息。
5.Client构建表示该文法定义的语言中一个特定的句子的抽象法树。该抽象语法书树由NonterminalExpression和TerminalExpression的实力装配而成,调用解析操作。
四。类图。
五。实例
AbstractExpression
Expression
Context
Test
result