欢迎光临散文网 会员登陆 & 注册

设计模式:解释器模式

2022-05-12 10:26 作者:做架构师不做框架师  | 我要投稿

什么是解释器模式

解释器模式(Interpreter Pattern),它指定如何评估语言中的句子。基本思想是用专门的计算机语言为每个符号(终端或非终端)创建一个类。

语言中句子的句法树是解释器模式的一个实例,用于为客户评估(解释)句子。

一句话归纳

实现特定语言解析

示例

我们每一个人都会从一个小孩子长成一个大人,在小的时候都会去幼儿园去学习,大家都会背过加法口诀等各种各样的方便记忆的口诀,1+1=2、1+2=3……

在1+1=2中,加号代表是非终结表达式,代表一种规则;等于号代表是终结表达式,解释器模式通常只有一个终结符表达式,但有多个实例,对应不同的终结符。

代码如下:

适用性

以下场景我建议你考虑使用

  • 可以将一个需要解释执行的语言中的句子表示为一个抽象语法树

  • 一些重复出现的问题可以用一种简单的语言来表达

  • 一个简单语法需要解释的场景

局限性

以下场景我建议你谨慎使用

  • 执行效率较低。解释器模式中通常使用大量的循环和递归调用,当要解释的句子较复杂时,其运行速度很慢,且调试过程也比较麻烦。

  • 会引起类膨胀。解释器模式中的每条规则至少需要定义一个类,当包含的规则很多时,类的个数将急剧增加,导致系统难以管理与维护

写在最后

好兄弟可以点赞并关注我的公众号“javaAnswer”,全部都是干货。


设计模式:解释器模式的评论 (共 条)

分享到微博请遵守国家法律