设计模式(022)行为型之解释器模式

devtools/2024/9/22 17:17:37/

        解释器模式是一种行为型设计模式,用于定义一种语言的文法,并且在该语言中解释句子的意义。这种模式通常用于实现编程语言解释器、正则表达式引擎等场景。
解释器模式中,主要有以下几个角色:
① 抽象表达式(AbstractExpression):定义了解释器的接口,包含一个 `interpret` 方法用于解释句子。
② 终结符表达式(TerminalExpression):实现了抽象表达式接口,代表文法中的终结符,比如变量或者常量。
③ 非终结符表达式(NonterminalExpression):实现了抽象表达式接口,代表文法中的非终结符,通常是由终结符表达式组成的组合。
④ 上下文环境(Context):包含了解释器解释的上下文信息,可能影响解释的结果。
⑤ 客户端(Client):构建待解释的语句,并将其传递给解释器进行解释。
解释器模式通过组合表达式来解释句子,将复杂的语法规则分解成简单的表达式,然后递归地解释每个表达式,最终得到结果。

1、场景设计

实现场景:使用解释器模式模拟一个简单的布尔表达式。

2、C++实现

模拟了一个简单的布尔表达式解释器。`Context` 类表示上下文环境,存储了变量的值。`Expression` 是抽象表达式类,定义了解释器的接口。`TerminalExpression` 是终结符表达式类,表示单个变量的值。`OrExpression` 是非终结符表达式类,表示两个表达式的逻辑或操作。在 `main` 函数中,我们设置了变量 A 和 B 的值,并构建了一个逻辑或表达式,最后对该表达式进行解释。 

#include <iostream>
#include <unordered_map>
#include <string>// 上下文环境类
class Context {private:std::unordered_map<std::string, bool> variables;public:void setVariable(const std::string& name, bool value) {variables[name] = value;}bool getVariable(const std::string& name) {return variables[name];}
};// 抽象表达式类
class Expression {public:virtual bool interpret(Context& context) = 0;
};// 终结符表达式类
class TerminalExpression : public Expression {private:std::string variable;public:TerminalExpression(const std::string& variable) : variable(variable) {}bool interpret(Context& context) override {return context.getVariable(variable);}
};// 非终结符表达式类
class OrExpression : public Expression {private:Expression* expression1;Expression* expression2;public:OrExpression(Expression* expr1, Expression* expr2) : expression1(expr1), expression2(expr2) {}bool interpret(Context& context) override {return expression1->interpret(context) || expression2->interpret(context);}~OrExpression() {delete expression1;delete expression2;}
};// 客户端代码
int main() {Context context;context.setVariable("A", true);context.setVariable("B", false);Expression* expression = new OrExpression(new TerminalExpression("A"), new TerminalExpression("B"));std::cout << "A OR B is: " << expression->interpret(context) << std::endl;delete expression;return 0;
}

3、Java实现

模拟了一个简单的布尔表达式解释器。`Context` 类表示上下文环境,存储了变量的值。`Expression` 是抽象表达式接口,定义了解释器的方法。`TerminalExpression` 是终结符表达式类,表示单个变量的值。`OrExpression` 是非终结符表达式类,表示两个表达式的逻辑或操作。在 `main` 方法中,我们设置了变量 A 和 B 的值,并构建了一个逻辑或表达式,最后对该表达式进行解释。 

package behavioralpattern.interpreter;import java.util.HashMap;
import java.util.Map;// 上下文环境类
class Context {private Map<String, Boolean> variables = new HashMap<>();public void setVariable(String name, boolean value) {variables.put(name, value);}public boolean getVariable(String name) {return variables.getOrDefault(name, false);}
}// 抽象表达式类
interface Expression {boolean interpret(Context context);
}// 终结符表达式类
class TerminalExpression implements Expression {private String variable;public TerminalExpression(String variable) {this.variable = variable;}@Overridepublic boolean interpret(Context context) {return context.getVariable(variable);}
}// 非终结符表达式类
class OrExpression implements Expression {private Expression expression1;private Expression expression2;public OrExpression(Expression expression1, Expression expression2) {this.expression1 = expression1;this.expression2 = expression2;}@Overridepublic boolean interpret(Context context) {return expression1.interpret(context) || expression2.interpret(context);}
}public class InterpreterDemo {public static void main(String[] args) {Context context = new Context();context.setVariable("A", true);context.setVariable("B", false);Expression expression = new OrExpression(new TerminalExpression("A"), new TerminalExpression("B"));System.out.println("A OR B is: " + expression.interpret(context));}
}

http://www.ppmy.cn/devtools/7844.html

相关文章

基础知识集合

https://blog.csdn.net/sheng_q/category_10901984.html?spm1001.2014.3001.5482 字节流&#xff1a;面向字节的io流&#xff0c;音频 图片 歌曲 byteArray/stringbuffer/file/piped/sequence /filter/data/buffer缓冲/lineNumber/pushedbackInputStream byte/file/piped/…

数据结构之双链表的相关知识点及应用

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a;数据结构 目录 双链表的实现 初始化双链表 在双链表中尾插数据 在双链表中尾删数据 在双链表中头插数据 在双链表中头删数据 在双…

能源成果3D网络三维展厅越发主流化

在这个数字化飞速发展的时代&#xff0c;我们为您带来了全新的展览形式——线上3D虚拟展厅。借助VR虚拟现实制作和web3d开发技术&#xff0c;我们能够将物品、图片、视频和图文信息等完美融合&#xff0c;通过计算机技术和3D建模&#xff0c;为您呈现一个逼真、生动的数字化展览…

Dynamic Wallpaper for Mac激活版:视频动态壁纸软件

Dynamic Wallpaper for Mac 是一款为Mac电脑量身打造的视频动态壁纸应用&#xff0c;为您的桌面带来无限生机和创意。这款应用提供了丰富多样的视频壁纸选择&#xff0c;涵盖了自然风景、抽象艺术、科幻奇观等多种主题&#xff0c;让您的桌面成为一幅活生生的艺术画作。 Dynami…

iOS NSFileManager获取设备硬盘剩余可用容量不准确问题

方法1. 通用 NSFileManager attributesOfFileSystemForPath: error: 方法2. available(iOS 11.0) NSURL resourceValuesForKeys: error: 发现问题&#xff1a;方法1获取到的剩余值并不准确&#xff0c;测得使用剩余值远小于实际的手机存储容量剩余。所以使用方法2优先。下面代…

【js】解决读取文件源内容总是得到默认index.html

在项目开发中&#xff0c;资源的获取都可以通过网络&#xff0c;所以获取文件内容&#xff0c;只需要将文件地址作为请求发送即可 读取文件源内容 const path 资源地址&#xff08;必须是绝对路径&#xff09;fetch(path).then((response) > {if (!response.ok) {throw ne…

数据仓库、数据中台、大数据平台的关系?

一、数据中台 数据中台是一个数据运营的概念&#xff0c;主要功能是将跨领域的数据集中聚合和治理&#xff0c;将其抽象为服务&#xff0c;提供具有业务价值的逻辑概念。 相较于传统的大数据平台&#xff0c;数据中台是升级版的概念&#xff0c;并不再简单地将各个功能混在一起…

【蓝桥杯2025备赛】集合求和

集合求和 题目描述 给定一个集合 s s s&#xff08;集合元素数量 ≤ 30 \le 30 ≤30&#xff09;&#xff0c;求出此集合所有子集元素之和。 输入格式 集合中的元素&#xff08;元素 ≤ 1000 \le 1000 ≤1000&#xff09; 输出格式 s s s 所有子集元素之和。 样例 #1 …