设计模式:解释器模式
什么是解释器模式
解释器模式(Interpreter Pattern),它指定如何评估语言中的句子。基本思想是用专门的计算机语言为每个符号(终端或非终端)创建一个类。
语言中句子的句法树是解释器模式的一个实例,用于为客户评估(解释)句子。
一句话归纳
实现特定语言解析
示例
我们每一个人都会从一个小孩子长成一个大人,在小的时候都会去幼儿园去学习,大家都会背过加法口诀等各种各样的方便记忆的口诀,1+1=2、1+2=3……
在1+1=2中,加号代表是非终结表达式,代表一种规则;等于号代表是终结表达式,解释器模式通常只有一个终结符表达式,但有多个实例,对应不同的终结符。
代码如下:

适用性
以下场景我建议你考虑使用
可以将一个需要解释执行的语言中的句子表示为一个抽象语法树
一些重复出现的问题可以用一种简单的语言来表达
一个简单语法需要解释的场景
局限性
以下场景我建议你谨慎使用
执行效率较低。解释器模式中通常使用大量的循环和递归调用,当要解释的句子较复杂时,其运行速度很慢,且调试过程也比较麻烦。
会引起类膨胀。解释器模式中的每条规则至少需要定义一个类,当包含的规则很多时,类的个数将急剧增加,导致系统难以管理与维护
写在最后
好兄弟可以点赞并关注我的公众号“javaAnswer”,全部都是干货。
