设计模式-解释器设计模式
文章目录
- 前言
- 一、 解释器模式的结构
- 1、抽象表达式(Abstract Expression)
- 2、终结符表达式(Terminal Expression)
- 3、非终结符表达式(Non-terminal Expression)
- 4、上下文(Context)
- 5、客户端(Client)
- 二、解析器的优缺点
- 1、 优点:
- 2、 缺点:
- 二、 解释器模式的实现
- 1、抽象表达式接口
- 2、创建终结符表达式
- 3、定义上下文
前言
解释器模式(Interpreter Pattern)是一种行为型设计模式,它用于解释一种语言或表达式的语法。该模式主要用于自定义语言解释、查询解析和规则引擎等领域。在解释器模式中,我们定义了一个解释器类,用于解释和执行特定语法规则的表达式。
在本篇博客中,我们将详细介绍解释器模式的概念,并提供一个简单的Java代码示例来演示如何实现它。
一、 解释器模式的结构
解释器模式包含以下主要组件:
1、抽象表达式(Abstract Expression)
定义一个抽象的解释器接口,包含解释方法,所有具体表达式都必须实现这个接口。
2、终结符表达式(Terminal Expression)
实现抽象表达式接口,用于表示语言中的终结符,这些终结符是不可再分的基本元素。
3、非终结符表达式(Non-terminal Expression)
实现抽象表达式接口,用于表示语言中的非终结符,这些非终结符可以由终结符和其他非终结符组合而成。
4、上下文(Context)
包含待解释的语句或表达式,提供对解释器的访问接口。
5、客户端(Client)
创建和配置解释器,将上下文传递给解释器以执行解释。
二、解析器的优缺点
解释器模式(Interpreter Pattern)是一种有用的设计模式,但它并不适用于所有情况。下面是解释器模式的优点和缺点:
1、 优点:
-
灵活性:解释器模式允许你轻松扩展语法和添加新的表达式。只需创建新的解释器类来处理新的表达式类型,而不需要修改现有代码。
-
可维护性:解释器模式将解释逻辑封装在独立的表达式类中,使得代码易于理解和维护。每个表达式类只负责处理特定类型的表达式,降低了类的复杂性。
-
自定义语言:解释器模式适用于自定义语言的实现。通过创建自己的表达式和解释器,可以构建和执行特定领域的语言,如规则引擎、查询语言等。
-
分离抽象语法树:解释器模式通过构建抽象语法树(Abstract Syntax Tree,AST)来表示和处理表达式,这有助于将语法结构分离开来,使得操作和修改语法更加直观。
2、 缺点:
-
复杂性:对于复杂的语法和大量表达式类型,解释器模式可能会导致类层次结构变得庞大复杂,难以维护。
-
性能问题:解释器模式通常不是处理大量数据或频繁执行的最佳选择。因为每个表达式都需要解释,可能导致性能问题。在某些情况下,可以使用编译技术将表达式转换为可执行代码来提高性能。
-
学习曲线:理解和实现解释器模式可能需要一些学习和适应时间。新团队成员可能需要一段时间来熟悉模式的工作原理。
-
不适用于简单表达式:对于非常简单的表达式或少量表达式类型,引入解释器模式可能会显得过于繁琐,不划算。
综上所述,解释器模式在特定情况下是一种非常有用的设计模式,尤其在自定义语言解释和规则引擎等领域有广泛应用。然而,需要根据具体的应用场景来权衡其优点和缺点,确保选择合适的设计模式来解决问题。
二、 解释器模式的实现
让我们通过一个简单的数学表达式解释器来演示解释器模式的实现。我们将支持对两个数字的加法和减法操作进行解释和计算。
1、抽象表达式接口
首先,我们定义抽象表达式接口 Expression:
interface Expression {int interpret(Context context);
}
2、创建终结符表达式
然后,我们创建终结符表达式 NumberExpression 和非终结符表达式 AdditionExpression 和 SubtractionExpression:
class NumberExpression implements Expression {private int number;public NumberExpression(int number) {this.number = number;}@Overridepublic int interpret(Context context) {return number;}
}class AdditionExpression implements Expression {private Expression left;private Expression right;public AdditionExpression(Expression left, Expression right) {this.left = left;this.right = right;}@Overridepublic int interpret(Context context) {return left.interpret(context) + right.interpret(context);}
}class SubtractionExpression implements Expression {private Expression left;private Expression right;public SubtractionExpression(Expression left, Expression right) {this.left = left;this.right = right;}@Overridepublic int interpret(Context context) {return left.interpret(context) - right.interpret(context);}
}
3、定义上下文
接下来,我们定义上下文 Context,它包含待解释的表达式和一些额外的信息:
class Context {private String input;private Map<Character, Integer> variables = new HashMap<>();public Context(String input) {this.input = input;}public void setVariable(char variable, int value) {variables.put(variable, value);}public int getVariableValue(char variable) {return variables.get(variable);}
}
最后,我们创建客户端代码,使用解释器来解释和计算数学表达式:
public class Client {public static void main(String[] args) {String expression = "a+b-c";Context context = new Context(expression);context.setVariable('a', 10);context.setVariable('b', 5);context.setVariable('c', 3);Expression exp = new SubtractionExpression(new AdditionExpression(new NumberExpression('a'), new NumberExpression('b')),new NumberExpression('c'));int result = exp.interpret(context);System.out.println("Expression result: " + result);}
}
在这个示例中,我们首先创建一个数学表达式字符串,然后通过上下文设置变量的值。接着,我们创建一个表达式解释器来解释表达式,并最终计算出结果。
解释器模式非常有用,特别是在自定义语言解释、规则引擎和查询解析等应用中。它允许我们灵活地扩展语法,同时将解释过程封装在独立的表达式类中,使得代码易于维护和扩展。
相关文章:
设计模式-解释器设计模式
文章目录 前言一、 解释器模式的结构1、抽象表达式(Abstract Expression)2、终结符表达式(Terminal Expression)3、非终结符表达式(Non-terminal Expression)4、上下文(Context)5、客…...
实现 js 中所有对象的深拷贝(包装对象,Date 对象,正则对象)
通过递归可以简单实现对象的深拷贝,但是这种方法不管是 ES6 还是 ES5 实现,都有同样的缺陷,就是只能实现特定的 object 的深度复制(比如数组和函数),不能实现包装对象 Number,String ࿰…...
PathVariable注解
postman测试传参:http://localhost:8080/admin/employee/2 PathVariable PathVariable注解用法和作用...
宋浩高等数学笔记(十二)无穷级数
完结,宋浩笔记系列的最后一更~ 之后会出一些武忠祥老师的错题&笔记总结,10月份就要赶紧做真题了...
使用Clipboard插件实现Vue的剪贴板功能
在Web开发中,剪贴板功能是一个常见但又非常有用的功能。通过将数据复制到剪贴板,用户可以方便地将数据粘贴到其他应用程序或网站上。在本文中,我们将介绍如何使用Clipboard插件结合Vue框架实现剪贴板功能。 Clipboard插件简介 Clipboard插件…...
Latex参考文献中大写字母编译后自动变成了小写,如何保持原字母大写形式
一、问题 1.1 bib文件原有内容 以下参考文献中MANET为大写 inproceedings{Miao2013FullySK, title{Fully Self-organized Key Management Scheme in MANET and Its Applications}, author{Fuyou Miao and Wenjing Ruan and Xianchang Du and Suwan Wang}, year{2013} } …...
Jest单元测试相关
官方文档:jest 中文文档 1、模拟某个函数,并返回指定的结果 使用Jest测试JavaScript(Mock篇) 有这样一个需求,mock掉Math.random方法(0(包括)~1之间),使其返回指定的0…...
Scrum敏捷开发流程及关键环节
Scrum是一种敏捷开发流程,它旨在使软件开发更加高效和灵活。Scrum将软件开发过程分为多个短期、可重复的阶段,称为“Sprint”。每个Sprint通常为两周,旨在完成一部分开发任务。 在Scrum中,有一个明确的角色分工: 产…...
微服务04-Gateway网关
作用 身份认证:用户能不能访问 服务路由:用户访问到那个服务中去 负载均衡:一个服务可能有多个实例,甚至集群,负载均衡就是你的请求到哪一个实例上去 请求限流功能:对请求进行流量限制,对服务…...
YOLOV7改进-针对小目标的NWD(损失函数)
link 1、复制这些 2、utils-loss,这里加 3、把这几行复制到utiils的loss.py 4、先对CoputerLoss类做修改 5、把那一行替换成这个 6、修改 7、iou_ration是超参,可以调,如果小目标比较多的话,这个值可以低一些,…...
计算机二级考试题库及答案
题目一:计算机网络基础 1.计算机网络的定义是什么? 计算机网络是指由通讯设备和不同类型计算机组成的计算机系统,利用传输介质,如电缆、光缆、无线等与通讯协议,实现计算机之间的信息传递和共享资源。 2. 内网和外网有什么区别…...
2023国赛高教社杯数学建模C题思路分析
1 赛题 在生鲜商超中,一般蔬菜类商品的保鲜期都比较短,且品相随销售时间的增加而变差, 大部分品种如当日未售出,隔日就无法再售。因此, 商超通常会根据各商品的历史销售和需 求情况每天进行补货。 由于商超销售的蔬菜…...
Ansible playbook简介与初步实战,实现批量机器应用下载与安装
一.Ansible playbook简介 playbook是ansible用于配置,部署,和管理被节点的剧本通过playbook的详细描述,执行其中的一些列tasks,可以让远端的主机达到预期的状态。playbook就像ansible控制器给被控节点列出的一系列to-do-list&…...
[machine Learning]强化学习
强化学习和前面提到的几种预测模型都不一样,reinforcement learning更多时候使用在控制一些东西上,在算法的本质上很接近我们曾经学过的DFS求最短路径. 强化学习经常用在一些游戏ai的训练,以及一些比如火星登陆器,月球登陆器等等工程领域,强化学习的内容很简单,本质就是获取状…...
09-JVM垃圾收集底层算法实现
上一篇:08-JVM垃圾收集器详解 1.三色标记 在并发标记的过程中,因为标记期间应用线程还在继续跑,对象间的引用可能发生变化,多标和漏标的情况就有可能发生。 这里我们引入“三色标记”来给大家解释下,把Gcroots可达…...
系统软件启动过程
实验一:系统软件启动过程 参考 重要文件 调用顺序 1. boot/bootasm.S | bootasm.asm(修改了名字,以便于彩色显示)a. 开启A20 16位地址线 实现 20位地址访问 芯片版本兼容通过写 键盘控制器8042 的 64h端口 与 60h端口。b.…...
【自学笔记】Python中的逻辑函数:any()、all()及同类函数的用法与示例
文章目录 Python中的逻辑函数:any()、all()及其他any()函数使用示例all()函数使用示例其他同类函数Python中的逻辑函数:any()、all()及其他 在Python中,any()和all()是两种常用的逻辑函数,它们在处理布尔值(True或False)的集合时非常有用。除此之外,Python还提供了一些其…...
OpenCV的绘图函数,实力绘画篮球场
关键函数:cv2.line(),cv2.circle(),cv2.rectangle(),cv2.ellipse(),cv2.putText() 等。 绘制几何形状 import cv2 as cv import numpy as npcv.rectangle(),cv.circle(),cv.line(),…...
Java之包装类的算法小题的练习
算法小题 练习一: 需求: 键盘录入一些1~10日之间的整数,并添加到集合中。直到集合中所有数据和超过200为止。 代码示例: public class Test1 {public static void main(String[] args) {/*键盘录入一些1~10日之间的整数&…...
干涉阵相关知识
文章目录 Dirty ImageDirty BeamClean ImagePoint Spread Function(PSF)Station Beam关系Dirty Image 脏图像(Dirty Image): 脏图像是在射电干涉测量中观测到的图像,它是真实图像和仪器效应(包括PSF和站波束)的组合结果。 在射电干涉测量中,观测到的结果被称为“脏图像…...
19c补丁后oracle属主变化,导致不能识别磁盘组
补丁后服务器重启,数据库再次无法启动 ORA01017: invalid username/password; logon denied Oracle 19c 在打上 19.23 或以上补丁版本后,存在与用户组权限相关的问题。具体表现为,Oracle 实例的运行用户(oracle)和集…...
CVPR 2025 MIMO: 支持视觉指代和像素grounding 的医学视觉语言模型
CVPR 2025 | MIMO:支持视觉指代和像素对齐的医学视觉语言模型 论文信息 标题:MIMO: A medical vision language model with visual referring multimodal input and pixel grounding multimodal output作者:Yanyuan Chen, Dexuan Xu, Yu Hu…...
《Playwright:微软的自动化测试工具详解》
Playwright 简介:声明内容来自网络,将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具,支持 Chrome、Firefox、Safari 等主流浏览器,提供多语言 API(Python、JavaScript、Java、.NET)。它的特点包括&a…...
【机器视觉】单目测距——运动结构恢复
ps:图是随便找的,为了凑个封面 前言 在前面对光流法进行进一步改进,希望将2D光流推广至3D场景流时,发现2D转3D过程中存在尺度歧义问题,需要补全摄像头拍摄图像中缺失的深度信息,否则解空间不收敛…...
跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...
VTK如何让部分单位不可见
最近遇到一个需求,需要让一个vtkDataSet中的部分单元不可见,查阅了一些资料大概有以下几种方式 1.通过颜色映射表来进行,是最正规的做法 vtkNew<vtkLookupTable> lut; //值为0不显示,主要是最后一个参数,透明度…...
C# 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...
嵌入式学习笔记DAY33(网络编程——TCP)
一、网络架构 C/S (client/server 客户端/服务器):由客户端和服务器端两个部分组成。客户端通常是用户使用的应用程序,负责提供用户界面和交互逻辑 ,接收用户输入,向服务器发送请求,并展示服务…...
Java求职者面试指南:计算机基础与源码原理深度解析
Java求职者面试指南:计算机基础与源码原理深度解析 第一轮提问:基础概念问题 1. 请解释什么是进程和线程的区别? 面试官:进程是程序的一次执行过程,是系统进行资源分配和调度的基本单位;而线程是进程中的…...
从面试角度回答Android中ContentProvider启动原理
Android中ContentProvider原理的面试角度解析,分为已启动和未启动两种场景: 一、ContentProvider已启动的情况 1. 核心流程 触发条件:当其他组件(如Activity、Service)通过ContentR…...
