解释器模式

解释器模式定义

定义一个语言的文法,并且建立一个解释器来解释该语言中的句子,这里的“语言”是指使用规定格式和语法的代码,解释器模式是一种类行为型模式

解释器模式结构图

解释器模式_第1张图片
image.png

解释器模式主要优缺点

优点
1.易于改变和扩展文法。由于在解释器模式中使用类来表示语言的文法规则,因此可以通过继承等机制来改变或者扩展文法。
2.每一条文法规则都可以表示为一个类,因此可以方便地实现一个简单的语言。
3.实现文法较为容易。在抽象语法书中每一个表达式节点类的实现方式都是相似的。这些类的代码编写都不会特别复杂,还可以通过一些工具自动生成节点类代码。
4.增加新的解释表达比较方便,如果用户需要增加新的解释表达式只需要对应增加一个新的终结符表达式或非终结符表达式类,原有表达式类代码无须修改,闭合开闭原则。
缺点
1.对于复杂文法难以维护。在解释器模式中,每一条规则至少需要定义一个类,因此如果一个语言包包含太多文法规则,类的个数将会急剧增加。导致系统难易管理和维护,此时可以考虑使用语法分析程序等方式来取代解释器模式。
2.执行效率较低。由于在解释器模式中使用大量的循环和递归,因此在解释较为复杂的句子时其速度很慢,而且代码调用过程也比较麻烦。

解释器模式适用场景

1.可以将一个需要解释执行的语言中的句子表示为一个抽象语法树。
2.一些重复出现的问题可以用一个简单的语言来进行表达。
3.一个语言的文法比较简单。
4.执行效率不是关键问题。

你可能感兴趣的:(解释器模式)