zoukankan      html  css  js  c++  java
  • 解释器模式

    解释器(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; }
  • 相关阅读:
    java获取服务器的ip和地址
    如何产生好的词向量
    谈谈评价指标中的宏平均和微平均
    在NLP中深度学习模型何时需要树形结构?
    Windows下MetaMap工具安装
    ML 感知机(Perceptrons)
    ML 神经网络 NeuralNetworks
    NLP-特征选择
    ML 逻辑回归 Logistic Regression
    ML 线性回归Linear Regression
  • 原文地址:https://www.cnblogs.com/hupeng1234/p/6882179.html
Copyright © 2011-2022 走看看