Emove

  • 首页
  • 归档
  • 分类
  • 标签

  • 搜索
context 反射 channel LRU BeanDefinition JVM 装饰者模式 MyBatis 快慢指针 归并排序 链表 hash表 栈 回溯 贪心 主从复制 二分查找 双指针 动态规划 AOF RDB 规范 BASE理论 CAP B树 RocketMQ Sentinel Ribbon Eureka 命令模式 访问者模式 迭代器模式 中介者模式 备忘录模式 解释器模式 状态模式 策略模式 职责链模式 模板方法模式 代理模式 享元模式 桥接模式 外观模式 组合模式 适配器模式 建造者模式 原型模式 工场模式 单例 UML 锁 事务 sql 索引

解释器模式

发表于 2020-04-04 | 分类于 设计模式 | 17 | 阅读次数 165

解释器模式

基本介绍

  1. 在编译原理中,一个算术表达式通过词法分析器形成词法单元,而后这些词法单元在通过语法分析器构建语法分析树,最终形成一棵抽象的语法分析树。这里的词法分析和语法分析器都可以看做解释器
  2. 解释器模式(Interpreter)是指给定一个语言(表达式),定义它的文法的一种表示,并定义一个解释器,使用该解释器来解释语言中的句子(表达式)
  3. 应用场景:
    1. 应用可以将一个需要解释执行的语言中的句子表示为一个抽象的语法树
    2. 一些重复出现的问题可以用一种简单的语言来表达
    3. 一个简单语法需要解释的场景
    4. 比如编译器、运算表达式计算、正则表达式、机器人等

原理说明

解释器原理图

  1. Context:是环境角色,含有解释器之外的全局信息
  2. Expression:抽象表达式,声明抽象的解释操作,这个抽象方法,为抽象语法树中所有的节点所共享
  3. TerminalExpression:为终结符表达式,实现与文法中的终结符相关的解释操作
  4. NonTerminalExpression:为非终结表达式,为文法中的非终结符实现解释操作

注意事项和细节

  1. 当有一个语言需要解释执行,可将该语言中的句子表示为一个抽象语法树,就可以考虑使用解释器模式,让程序具有良好的扩展性
  2. 使用解释器可能带来的问题:解释器可能引起类膨胀,解释器模式采用递归调用的方法,将会导致调试非常复杂,效率可能降低
# context # 反射 # channel # LRU # BeanDefinition # JVM # 装饰者模式 # MyBatis # 快慢指针 # 归并排序 # 链表 # hash表 # 栈 # 回溯 # 贪心 # 主从复制 # 二分查找 # 双指针 # 动态规划 # AOF # RDB # 规范 # BASE理论 # CAP # B树 # RocketMQ # Sentinel # Ribbon # Eureka # 命令模式 # 访问者模式 # 迭代器模式 # 中介者模式 # 备忘录模式 # 解释器模式 # 状态模式 # 策略模式 # 职责链模式 # 模板方法模式 # 代理模式 # 享元模式 # 桥接模式 # 外观模式 # 组合模式 # 适配器模式 # 建造者模式 # 原型模式 # 工场模式 # 单例 # UML # 锁 # 事务 # sql # 索引
备忘录模式
状态模式
  • 文章目录
  •   |  
  • 概览
林亦庭

林亦庭

less can be more

87 文章
11 分类
54 标签
RSS
Github
Creative Commons
© 2021 林亦庭
粤ICP备20029050号