12.解释器模式

1解释器模式具体描述

解释器模式:给定一个语言后,解释器模式可以定义出其文法的一种表示,

并同时提供一个解释器。客户端可以使用这个解释器来解释这个语言中的句子。

解释器模式将描述怎样在有了一个简单的文法后,使用模式设计解释这些语句。

在解释器模式里面提到的语言是指任何解释器对象能够解释的任何组合。

在解释器模式中需要定义一个代表文法的命令类的等级结构,

也就是一系列的组合规则。每一个命令对象都有一个解释方法,

代表对命令对象的解释。命令对象的等级结构中的对象的任何排列组合都是一个语言。

 

俺有一个《泡MM真经》,上面有各种泡MM的攻略,比如说去吃西餐的步骤、

去看电影的方法等等,跟MM约会时,只要做一个Interpreter

照着上面的脚本执行就可以了。

4.观察者模式类图

5.代码:

#include<iostream>

#include <list>

#include <string>

using namespace std;

//解释器模式:给定一个语言后,解释器模式可以定义出其文法的一种表示,

//并同时提供一个解释器。客户端可以使用这个解释器来解释这个语言中的句子。

//解释器模式将描述怎样在有了一个简单的文法后,使用模式设计解释这些语句。

//在解释器模式里面提到的语言是指任何解释器对象能够解释的任何组合。

//在解释器模式中需要定义一个代表文法的命令类的等级结构,

//也就是一系列的组合规则。每一个命令对象都有一个解释方法,

//代表对命令对象的解释。命令对象的等级结构中的对象的任何排列组合都是一个语言。

//

//俺有一个《泡MM真经》,上面有各种泡MM的攻略,比如说去吃西餐的步骤、

//去看电影的方法等等,跟MM约会时,只要做一个Interpreter

//照着上面的脚本执行就可以了。

 

class Context;

 

class AbstractExpression

{

public:

    virtual void interpret(Context *) = 0;

};

 

class TerminalExpression :public AbstractExpression

{

public:

    void interpret(Context *context)

    {

        cout << "终端解释器" << endl;

    }

};

 

class NonterminalExpression :public AbstractExpression

{

public:

    void interpret(Context *context)

    {

        cout << "非终端解释器" << endl;

    }

};

 

class Context

{

public:

    string input, output;

};

 

int main()

{

    Context *context = new Context();

    list<AbstractExpression*>  lt;

    lt.push_back(new TerminalExpression());

    lt.push_back(new NonterminalExpression());

    lt.push_back(new TerminalExpression());

    lt.push_back(new TerminalExpression());

 

    for (list<AbstractExpression*>::iterator iter = lt.begin(); iter != lt.end(); iter++)

    {

        (*iter)->interpret(context);

    }

 

    cin.get();

    return 0;

}

运行结果如下:


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

涂作权的博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值