• 解释器模式


    解释器(interpreter)模式

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

    主要解决:对于一些固定文法构建一个解释句子的解释器。

    代码:

    #include <iostream>
    #include <map>
    #include <string>
    using namespace std;
    
    #define SAFE_DELETE(p) if ((p)) {delete (p); (p) = NULL;}
    
    class Context
    {
    public:
        void addValue(string key, int value)
        {
            //_valueMap.insert(pair<string, int>(key, value));
            _valueMap[key] = value;
        
        }
    
        int getValue(string key) const
        {
            return _valueMap.at(key);
        }
    
    private:
        map<string, int> _valueMap;
    };
    
    class AbstractExpression
    {
    public:
        virtual ~AbstractExpression() {}
        virtual int interpreter(const Context &context) = 0;
    };
    
    class AddNonterminalExpression : public AbstractExpression
    {
    public:
        AddNonterminalExpression(AbstractExpression *left, AbstractExpression *right) : _left(left), _right(right){}
        ~AddNonterminalExpression()
        {
            SAFE_DELETE(_left);
            SAFE_DELETE(_right);
        }
    virtual int interpreter(const Context &context) { return _left->interpreter(context) + _right->interpreter(context); } private: AbstractExpression *_left; AbstractExpression *_right; }; class SubstractNonterminalExpression : public AbstractExpression { public: SubstractNonterminalExpression(AbstractExpression *left, AbstractExpression *right) : _left(left), _right(right){} ~SubstractNonterminalExpression() { SAFE_DELETE(_left); SAFE_DELETE(_right); }
    virtual int interpreter(const Context &context) { return _left->interpreter(context) - _right->interpreter(context); } private: AbstractExpression *_left; AbstractExpression *_right; }; class TerminalExpression : public AbstractExpression { public: TerminalExpression(string key) { _key = key; }
    int interpreter(const Context &context) { return context.getValue(_key); } private: string _key; }; void test() { Context cxt; cxt.addValue("a", 1); cxt.addValue("b", 3); cxt.addValue("c", 5); // 1 + 3 AbstractExpression *addExpr = new AddNonterminalExpression(new TerminalExpression("a"), new TerminalExpression("b")); cout << addExpr->interpreter(cxt) << endl; // 4 - 5 AbstractExpression *subExpr = new SubstractNonterminalExpression(addExpr, new TerminalExpression("c")); cout << subExpr->interpreter(cxt) << endl; delete subExpr; } int main() { test(); cin.get(); return 0; }
  • 相关阅读:
    c# 泛型总结
    透过字节码分析java基本类型数组的内存分配方式。
    c#索引器
    redis在asp.net 中的应用
    Unity3D shaderLab
    Unity3d Asset Store 打不开
    C# 类型转换的开销
    [转]权重算法
    Coroutine的原理以及实现
    在Unity3D里使用WinForm
  • 原文地址:https://www.cnblogs.com/hupeng1234/p/6882179.html
Copyright © 2020-2023  润新知