设计模式(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;
}

四 优缺点总结

优点:

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

缺点:

  • 可利用场景比较少
  • 对于复杂的文法比较难维护
  • 解释器模式会引起类膨胀
  • 解释器模式采用递归调用方法
相关推荐
Larcher9 小时前
AI Loop:让AI像人一样自主完成任务的核心机制
javascript·人工智能·设计模式
clint45613 小时前
C++进阶(1)——前景提要
c++
夜悊17 小时前
C++代码示例:进制数简单生成工具
c++
郝学胜_神的一滴18 小时前
CMake 021: IF 条件判据详诠
c++·cmake
_wyt0011 天前
洛谷 B3930 [GESP202312 五级] 烹饪问题 题解
c++·gesp
咖啡八杯1 天前
GoF设计模式——享元模式
java·spring·设计模式·享元模式
玖玥拾1 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
один but you2 天前
constexpr函数
c++
凡人叶枫2 天前
Effective C++ 条款41:了解隐式接口和编译期多态
java·开发语言·c++·effective c++
凡人叶枫2 天前
Effective C++ 条款42:了解 typename 的双重意义
java·linux·服务器·c++