设计模式-解释器模式

解释器模式interpreter):

    给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。



    如果一种特定类型的问题发生的频率足够高,那么可能就值得将该问题的各个实例表示为一个简单语言中的句子。这样就可以构建一个解释器,该解释器通过解释这些句子来解决问题(比如正则表达式)。

解析器模式实现代码

#pragma once
#include <string>
#include <iostream>
using namespace std;

//Context 包含解释器之外的一些全局信息
class CContext
{
public:
	string m_strInput;
	CContext(const string &strInput)
	{
		m_strInput = strInput;
	}
};

//AbstractExpression(抽象表达式),声明一个抽象的解释操作,这个接口为抽象语法树中
//所有的节点所共享。
class CAbstractExpression
{
public:
	virtual void Interpret(CContext *pContext) = 0;
};

//TerminalExpression(终结符表达式),实现与文法中的终结符相关联的解释器操作。
//实现抽象表达式中所要求的接口,主要是一个interpret()方法。文法中每一个终结符
//都有一个具体终结表达式与之相对应。
class CTerminalExpression : public CAbstractExpression
{
public:
	void Interpret(CContext *pContext)
	{
		cout<<"zhongduanjiehsiqi:"<<pContext->m_strInput<<endl;
	}
};

//NonterminalExpression(非终结符表达式),为文法中的非终结符实现解释操作。
//对文法中每一条规则R1、R2......Rn都需要一个具体的非终结符表达式类。
//通过实现抽象表达式的interpret()方法实现解释器操作。解释操作以递归方式
//调用上面所提到的表达式R1、R2......Rn中各个符号的实例变量。
class CNonterminalExpression : public CAbstractExpression
{
public:
	void Interpret(CContext *pContext)
	{
		cout<<"feizhongduanjiehsiqi:"<<pContext->m_strInput<<endl;
	}
};
运客户端调用

#include "stdafx.h"
#include <list>
#include <iostream>
#include <windows.h>
#include "CinterpreterMode.h"

using namespace std;

int main()
{
	CContext *pContext = new CContext("test");
	list <CAbstractExpression *> lstWork;
	lstWork.clear();
	lstWork.push_back(new CTerminalExpression());
	lstWork.push_back(new CNonterminalExpression());
	lstWork.push_back(new CTerminalExpression());
	lstWork.push_back(new CTerminalExpression());
	for each(CAbstractExpression * i in lstWork)
	{
		i->Interpret(pContext);
		delete i;
	}
	delete pContext;

   return 0;
}
运行结果



原文地址:https://www.cnblogs.com/csnd/p/12062318.html