/*小鱼号的代码日志
* 设计模式
* 解释器模式
* 当一个语言需要解释执行,可将该语句中的句子表示为一个抽象语法树,
* 就可以考虑使用解释器模式,让程序具有良好的扩展性
* 带来的问题:
* 解释器模式会引起类膨胀,解释器模式采用递归调用的方法,将会导致
* 调用非常复杂,效率可能降低
* 实例:
* 计算加减乘除
*/
#include<iostream>
#include<map>
#include<stack>
using namespace std;
///抽象类表达式 通过map可以获取变量的值
class Expression
{
public:
virtual int interpreter(map<char,int> var) = 0;
};
///变量的解释器
class VarExpression :public Expression
{
public:
VarExpression(char key)
{
m_key = key;
}
virtual int interpreter(map<char,int> var)
{
return var[m_key];
}
private:
char m_key;
};
///抽象运算符号解析器 每个运算符号都只和自己左右连个数字有关系
///但左右两个数字有可能也是一个解析的结果,无论何种类型都是expression类的实现类
class SymbolExpression:public Expression
{
public:
SymbolExpression(Expression* leftExpression,Expression* rightExpression)
{
m_leftExpression = leftExpression;
m_rightExpression = rightExpression;
}
///因为sybmol 是让子类来实现 因此interpreter是一个默认的实现
int interpreter(map<char, int> var)
{
return 0;
}
protected:
Expression* m_leftExpression;
Expression* m_rightExpression;
};
class AddExpression :public SymbolExpression
{
public:
AddExpression(Expression* leftExpression ,Expression* rightExpression):
SymbolExpression(leftExpression,rightExpression)
{
}
virtual int interpreter(map<char,int> var)
{
return m_leftExpression->interpreter(var) + m_rightExpression->interpreter(var);
}
};
class SubExpression :public SymbolExpression
{
public:
SubExpression(Expression* leftExpression ,Expression* rightExpression):
SymbolExpression(leftExpression,rightExpression)
{
}
virtual int interpreter(map<char,int> var)
{
return m_leftExpression->interpreter(var) - m_rightExpression->interpreter(var);
}
};
class Calculator
{
public:
Calculator(string expStr)
{
stack<Expression*> stack;
Expression* left = nullptr;
Expression* right = nullptr;
for(int i = 0; i < expStr.size(); i++)
{
switch (expStr[i])
{
case '+':
left = stack.top();
stack.pop();
right = new VarExpression(expStr[++i]);
stack.push(new AddExpression(left,right));
break;
case '-':
left = stack.top();
stack.pop();
right = new VarExpression(expStr[++i]);
stack.push(new SubExpression(left,right));
break;
default:
stack.push(new VarExpression(expStr[i]));
}
}
m_expression = stack.top();
}
int run(map<char,int> var)
{
return m_expression->interpreter(var);
}
private:
Expression* m_expression;
};
///解释器模式
void testInterpreter()
{
cout << "interpreter patterns" << endl;
///利用解释器模式计算表达式a+b-c
Calculator calc("a-b+c");
map<char,int> var;
var.insert(make_pair('a',10));
var.insert(make_pair('b',5));
var.insert(make_pair('c',7));
cout << calc.run(var) << endl;
map<char,int> var2;
var2.insert(make_pair('a',8));
var2.insert(make_pair('b',1));
var2.insert(make_pair('c',50));
cout << calc.run(var2) << endl;
}
【C++设计模式】 解释器模式
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
相关阅读更多精彩内容
- 解释器模式:一种行为型设计模式 首先,我想先说明一下,解释器模式是我个人认为最复杂的设计模式,可能因为我目前对编程...
- 用c语言手搓一个600行的类c语言解释器: 给编程初学者的解释器教程(2)- 简介和设计 项目github地址及源...