设计模式(C++)-行为型模式-解释器模式

设计模式(C++)-行为型模式-解释器模式

一、解释器模式概述

解释器模式(Interpreter Pattern):是一种行为型模式,用于定义语言的文法规则,并建立一个解释器来解释该语言中的句子。
核心思想 :将语言中的每个语法规则表示为一个类,通过组合这些类的实例来构建语法抽象树,然后遍历这颗树来解释执行。
应用场景

  • 1、应用可以将一个需要解释执行的语言中的句子表示为一个抽象语法树
  • 2、一些重复出现的问题可以用一种简单的语言来表达
  • 3、一个简单语法需要解释的场景
  • 4、这样的例子还有,比如编译器、运算表达式计算、正则表达式、机器人等

二、解释器模式UML类图

解释器场景

假设现在我们需要实现一个算术表达式的解释器,具体UML类图如下:

三、代码实现

cpp 复制代码
//interpreter.h
#pragma once
/*Interpreter 模式(解释器模式)
- 在编译原理中,一个算术表达式通过词法分析器形成词法单元,而后这些词法单元再通过语法分析器构建语法分析树,
最终形成一颗抽象的语法分析树。这里的词法分析器和语法分析器都可以看做是解释器
- 解释器模式(Interpreter Pattern):是指给定一个语言(表达式),定义它的文法的一种表示,并定义一个解释器,
使用该解释器来解释语言中的句子(表达式)
- 应用场景:
- 1、应用可以将一个需要解释执行的语言中的句子表示为一个抽象语法树
- 2、一些重复出现的问题可以用一种简单的语言来表达
- 3、一个简单语法需要解释的场景
- 4、这样的例子还有,比如编译器、运算表达式计算、正则表达式、机器人等
优点:
- 可扩展性比较好,灵活。
- 增加了新的解释表达式的方式。
- 易于实现简单文法。
缺点:
- 可利用场景比较少。
- 对于复杂的文法比较难维护。
- 解释器模式会引起类膨胀。
- 解释器模式采用递归调用方法
*/
#include <iostream>
#include <string>
using namespace std;
//抽象表达式类
class IExpression{
public:
	virtual ~IExpression() {};
	virtual int evaluate() = 0;
};
//终结符表达式 - 数字
class NumberExpression:public IExpression {
public:
	NumberExpression(int val) :m_value(val) {}
	virtual int evaluate()override;
private:
	int m_value;
};
//非终结符表达式 - 加法
class AddExpression:public IExpression{
public:
	AddExpression(IExpression *l, IExpression *r) : left(l), right(r) {}
	virtual int evaluate()override;
private:
	IExpression *left;
	IExpression *right;
};

// 非终结符表达式 - 减法
class SubtractExpression : public IExpression {
private:
	IExpression *left;
	IExpression *right;
public:
	SubtractExpression(IExpression *l, IExpression *r) : left(l), right(r) {}
	virtual int evaluate() override;
};

void testInterPreter();
//interpreter.cc
#include "interpreter.h"
int NumberExpression::evaluate() {
	return m_value;
}
int AddExpression::evaluate() {
	return left->evaluate() + right->evaluate();
}
int SubtractExpression::evaluate() {
	return left->evaluate() - right->evaluate();
}
void testInterPreter() {
	cout << "=================InterPreter begin===============" << endl;
	IExpression *num1 = new NumberExpression(5);
	IExpression *num2 = new NumberExpression(3);

	IExpression *addExpr = new AddExpression(num1, num2);
	IExpression *subExpr = new SubtractExpression(num1, num2);

	std::cout << "加法结果: " << addExpr->evaluate() << std::endl;
	std::cout << "减法结果: " << subExpr->evaluate() << std::endl;

	delete num1;
	delete num2;
	delete addExpr;
	delete subExpr;
	cout << "=================InterPreter begin===============" << endl;
}

四 优缺点总结

优点:

  • 可扩展性好,灵活
  • 增加了新的解释表达式的方式
  • 易于实现简单文法

缺点:

  • 可利用场景比较少
  • 对于复杂的文法比较难维护
  • 解释器模式会引起类膨胀
  • 解释器模式采用递归调用方法
相关推荐
钝挫力PROGRAMER1 小时前
static final 指向可变集合的设计模式
java·设计模式
2401_897190551 小时前
【C++高阶系列】告别内查找局限:基于磁盘 I/O 视角的 B 树深度剖析与 C++ 泛型实现!
java·c++·算法
m2xgo1 小时前
ThreadPoolexecutor源码分析、C++11线程池实现
开发语言·c++
悲伤小伞2 小时前
LeetCode 热题 100_3-128. 最长连续序列
c++·算法·leetcode·哈希算法
学困昇2 小时前
彻底搞懂 Linux 基础 IO:文件描述符、重定向、dup2、缓冲区一次讲透!
linux·运维·服务器·开发语言·c++
杜子不疼.2 小时前
【C++ 在线五子棋对战】 - 项目介绍与环境搭建
开发语言·c++
Hical613 小时前
C++20 实战心得:现代 C++ 真正成熟的一代
c++·开源
努力努力再努力wz3 小时前
【Qt 入门系列】从应用场景到开发环境:建立对 Qt 的第一层认知
c语言·开发语言·数据库·c++·b树·qt·缓存
无限进步_3 小时前
【C++】红黑树完全解析:从概念到插入与平衡维护
java·c语言·开发语言·数据结构·c++·后端·算法