12.解释器模式
来源:互联网 发布:骨科医生 知乎 编辑:程序博客网 时间:2024/06/08 15:08
1解释器模式具体描述
解释器模式:给定一个语言后,解释器模式可以定义出其文法的一种表示,
并同时提供一个解释器。客户端可以使用这个解释器来解释这个语言中的句子。
解释器模式将描述怎样在有了一个简单的文法后,使用模式设计解释这些语句。
在解释器模式里面提到的语言是指任何解释器对象能够解释的任何组合。
在解释器模式中需要定义一个代表文法的命令类的等级结构,
也就是一系列的组合规则。每一个命令对象都有一个解释方法,
代表对命令对象的解释。命令对象的等级结构中的对象的任何排列组合都是一个语言。
俺有一个《泡MM真经》,上面有各种泡MM的攻略,比如说去吃西餐的步骤、
去看电影的方法等等,跟MM约会时,只要做一个Interpreter,
照着上面的脚本执行就可以了。
4.观察者模式类图
5.代码:
#include<iostream>
#include<list>
#include<string>
usingnamespacestd;
//解释器模式:给定一个语言后,解释器模式可以定义出其文法的一种表示,
//并同时提供一个解释器。客户端可以使用这个解释器来解释这个语言中的句子。
//解释器模式将描述怎样在有了一个简单的文法后,使用模式设计解释这些语句。
//在解释器模式里面提到的语言是指任何解释器对象能够解释的任何组合。
//在解释器模式中需要定义一个代表文法的命令类的等级结构,
//也就是一系列的组合规则。每一个命令对象都有一个解释方法,
//代表对命令对象的解释。命令对象的等级结构中的对象的任何排列组合都是一个语言。
//
//俺有一个《泡MM真经》,上面有各种泡MM的攻略,比如说去吃西餐的步骤、
//去看电影的方法等等,跟MM约会时,只要做一个Interpreter,
//照着上面的脚本执行就可以了。
classContext;
classAbstractExpression
{
public:
virtualvoidinterpret(Context *) = 0;
};
classTerminalExpression :publicAbstractExpression
{
public:
voidinterpret(Context *context)
{
cout <<"终端解释器" << endl;
}
};
classNonterminalExpression :publicAbstractExpression
{
public:
voidinterpret(Context *context)
{
cout <<"非终端解释器" << endl;
}
};
classContext
{
public:
stringinput,output;
};
intmain()
{
Context *context = newContext();
list<AbstractExpression*> lt;
lt.push_back(newTerminalExpression());
lt.push_back(newNonterminalExpression());
lt.push_back(newTerminalExpression());
lt.push_back(newTerminalExpression());
for (list<AbstractExpression*>::iteratoriter =lt.begin();iter !=lt.end();iter++)
{
(*iter)->interpret(context);
}
cin.get();
return 0;
}
运行结果如下:
- 12.解释器模式
- 深入浅出解释器模式
- 解释器(Interpreter )模式
- Interpreter解释器模式
- Interperter 解释器模式
- 解释器模式 InterpretePattern
- 解释器模式
- 解释器模式
- 深入浅出解释器模式
- 解释器模式(python)
- 解释器模式
- 解释器模式 详解
- 解释器模式
- Java解释器模式
- 解释器模式
- Interpreter 解释器模式
- java 解释器模式
- 解释器模式
- 10.观察者模式
- 11.建造者模式
- poj2409 Let it Bead polya定理
- Oracle相同用户相同库Copy表结构
- linux 安装并配置github
- 12.解释器模式
- 13.命令模式
- 对分区表创建本地索引的问题
- 14.模板模式
- Marlin固件显示其他Gcode文件扩展名
- 15.桥接模式
- nyoj275花队的烦恼
- 最小费用最大流
- 16.适配器模式