青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

積木

No sub title

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

常用鏈接

留言簿(1)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

轉載自:http://patmusing.blog.163.com/blog/static/13583496020101501515558/

在軟件構建過程中,如果某一特定領域的問題比較復雜,類似的模式不斷重復出現,如果使用普通的編程方式來實現將面臨非常頻繁的變化。在這種情況下,將特定領域的問題表達為某種語法規則下的句子,然后構建一個解釋器來解釋這樣的句子,從而達到解決問題的目的。

 

“Given a language, define a represention for its grammar along with an interpreter that uses the representation to interpret sentences in the language.” -GoF

給定一個語言,定義其文法的一種表示,并定義一個解釋器,這個解釋器使用該表示來解釋語言中的句子。

18. C++實現Behavioral - Interpreter模式 - 玄機逸士 - 玄機逸士博客

Interpreter設計模式中的幾種角色:

AbstractExpression:

- 聲明一個抽象的Interpret方法,抽象語法樹中所有的節點都必須實現該抽象方法。

TerminalExpression:

- 實現和語法中末端符號相關的Interpret方法。

- 在每個句子的末端符號中均需要一個TerminalExpression實例。

NonterminalExpression:

另外一個實現了AbstractExpression 接口的類,用來處理語法樹中非末端節點的語法。它含有下一個AbstractExpression(s)的引用,調用它每個子節點的Interpret方法。

Context:

Interpreter方法所需要的信息的容器,該信息對Interpreter而言全局可見。充當幾個AbstractExpresssion 實例之間的通訊頻道。

PatternClient:

構建或者接收一個抽象語法書的實例。對于一個特定的句子而言,語法樹往往由若干個TerminalExpressions NonterminalExpression組成。PatterClient在合適的context下,調用Interpret方法。

Interpreter模式的應用場合是interpreter模式應用中的難點,只有滿足業務規則頻繁變化,且類似的模式不斷重復出現,并且容易抽象為語法規則的問題才適合使用Interpreter模式。

使用Interpreter模式來表示文法規則,從而可以使用面向對象技巧來方便地擴展文法。

Interpreter模式比較適合簡單的文法表示,對于復雜的文法表示,Interpreter模式會產生比較大的類層次結構,這時候就不應該采用Interpreter模式了。

效率不是一個Interpreter關心的關鍵問題。最高效的解釋器通常不是通過直接解釋語法分析樹實現的,而是首先將它們轉換成另一種形式。例如:正則表達式通常被轉換成狀態機。但即使在這種情況下,如果效率不是一個關鍵問題,轉換器仍可用Interpreter模式實現,該模式仍是有用的。

下面是一個將中文數字轉換成阿拉伯數字的例子,其中用到了Interpreter

// Interpreter.h

#include <iostream>

#include <string>

#include <map>

#include <vector>

using namespace std;

// 下面兩個全局函數,用于處理寬字符中文

// 字符串轉換:string to wstring

wstring s2ws(const std::string& s)

{

setlocale(LC_ALL, "chs");

const char* _Source = s.c_str();

size_t _Dsize = s.size() + 1;

wchar_t *_Dest = new wchar_t[_Dsize];

wmemset(_Dest, 0, _Dsize);

mbstowcs(_Dest,_Source,_Dsize);

std::wstring result = _Dest;

delete []_Dest;

setlocale(LC_ALL, "C");

return result;

}

// 字符串轉換:wstring to string

string ws2s(const std::wstring& ws)

{

std::string curLocale = setlocale(LC_ALL, NULL); // curLocale = "C";

setlocale(LC_ALL, "chs");

const wchar_t* _Source = ws.c_str();

size_t _Dsize = 2 * ws.size() + 1;

char *_Dest = new char[_Dsize];

memset(_Dest,0,_Dsize);

wcstombs(_Dest,_Source,_Dsize);

std::string result = _Dest;

delete []_Dest;

setlocale(LC_ALL, curLocale.c_str());

return result;

}

// Context類,用于保存需要轉換的中文字符串和轉換后的數據

class Context

{

private:

wstring statement; // 需要轉換的中文字符串

int data; // 轉換后的數據

public:

Context(wstring statement) : statement(statement)

{

data = 0;

}

~Context()

{

cout << "in the destructor of Context..." << endl;

}

public:

void set_statement(wstring statement)

{

this->statement = statement;

}

wstring get_statement()

{

return statement;

}

void set_data(int data)

{

this->data = data;

}

int get_data()

{

return data;

}

};

// 抽象Expression

class Expression

{

protected:

map<string, int> dictionary; // 字典,保存與中文對應的阿拉伯數字

public:

Expression()

{

dictionary.insert(pair<string, int>("", 1));

dictionary.insert(pair<string, int>("", 2));

dictionary.insert(pair<string, int>("", 3));

dictionary.insert(pair<string, int>("", 4));

dictionary.insert(pair<string, int>("", 5));

dictionary.insert(pair<string, int>("", 6));

dictionary.insert(pair<string, int>("", 7));

dictionary.insert(pair<string, int>("", 8));

dictionary.insert(pair<string, int>("", 9));

dictionary.insert(pair<string, int>("", 0));

}

virtual ~Expression()

{

cout << "in the destructor of Expression..." << endl;

}

public:

virtual void Interpret(Context& ctx)

{

wstring statement = ctx.get_statement(); // ctx中取出中文字符串

wstring zero_string(s2ws("")); // 寬字符串

//wstring tempstr = statement.substr(statement.size() - 1);

if(statement.size() == 0) // ctx中取出的中文字符串長度等于

{

return; // 處理完成,返回

}

else if(statement.substr(statement.size() - 1) == zero_string) // 如果寬字符串中最后一個寬字符為

{

wstring tempstr = statement;

tempstr = tempstr.substr(0, tempstr.size() - 1); // 將最后的去掉

ctx.set_statement(tempstr);

return;

}

else

{

for(map<string, int>::iterator it = dictionary.begin(); it != dictionary.end(); it++)

{

int value = it->second; // 從字典中取出對應的數字

wstring tempstr2 = statement.substr(statement.size() - get_length());

wstring tempstr3 = s2ws(it->first) + get_postfix();

if(statement.substr(statement.size() - get_length()) == (s2ws(it->first) + get_postfix()))

{

int temp_data = ctx.get_data(); // 取出ctx中保存的數據

temp_data += value * Multiplier();

ctx.set_data(temp_data);

wstring temp_str = ctx.get_statement();

temp_str = temp_str.substr(0, temp_str.size() - get_length());

ctx.set_statement(temp_str);

return;

}

}

}

}

int get_length()

{

return get_postfix().size() + 1;

}

public:

virtual wstring get_postfix() = 0;

virtual int Multiplier() = 0;

};

// GeExpression

class GeExpression : public Expression

{

public:

wstring get_postfix()

{

return s2ws("");

}

int Multiplier()

{

return 1;

}

int get_length()

{

return 1;

}

public:

~GeExpression()

{

cout << "in the destructor of GeExpression..." << endl;

}

};

// ShExpression

class ShExpression : public Expression

{

public:

wstring get_postfix()

{

return s2ws("");

}

int Multiplier()

{

return 10;

}

public:

~ShExpression()

{

cout << "in the destructor of ShExpression..." << endl;

}

};

// BaExpression

class BaExpression : public Expression

{

public:

wstring get_postfix()

{

return s2ws("");

}

int Multiplier()

{

return 100;

}

public:

~BaExpression()

{

cout << "in the destructor of BaExpression..." << endl;

}

};

// QiExpression

class QiExpression : public Expression

{

public:

wstring get_postfix()

{

return s2ws("");

}

int Multiplier()

{

return 1000;

}

public:

~QiExpression()

{

cout << "in the destructor of QiExpression..." << endl;

}

};

// WaExpression

class WaExpression : public Expression

{

public:

wstring get_postfix()

{

return s2ws("");

}

int Multiplier()

{

return 10000;

}

void Interpret(Context& ctx)

{

wstring statement = ctx.get_statement(); //一十九零七百三十一萬

wstring zero_string(s2ws(""));

if(statement.size() == 0)

{

return; // 處理完成,返回

}

else if(statement.substr(statement.size() - 1) == zero_string)

{

wstring tempstr = statement;

tempstr = tempstr.substr(0, tempstr.size() - 1);

ctx.set_statement(tempstr);

return;

}

else

{

vector<Expression*> stx_tree;

stx_tree.push_back(new GeExpression());

stx_tree.push_back(new ShExpression());

stx_tree.push_back(new BaExpression());

stx_tree.push_back(new QiExpression());

if(statement.substr(statement.size() - 1) == get_postfix())

{

int temp_data = ctx.get_data();

ctx.set_data(0);

statement = statement.substr(0, statement.size() - 1);

ctx.set_statement(statement);

for(vector<Expression*>::iterator it = stx_tree.begin(); it != stx_tree.end(); it++)

{

if(ctx.get_statement().size() == 0) break;

(*it)->Interpret(ctx);

}

ctx.set_data(temp_data + ctx.get_data() * Multiplier());

// 刪除語法樹中動態構造的元素,以免內存泄漏

for(vector<Expression*>::iterator it = stx_tree.begin(); it != stx_tree.end(); )

{

Expression *temp = *it;

it = stx_tree.erase(it);

delete temp;

}

return;

}

}

}

public:

~WaExpression()

{

cout << "in the destructor of WaExpression..." << endl;

}

};

// YiExpression

class YiExpression : public Expression

{

public:

wstring get_postfix()

{

return s2ws("");

}

int Multiplier()

{

return 100000000;

}

void Interpret(Context& ctx)

{

wstring statement = ctx.get_statement();

wstring zero_string(s2ws(""));

if(statement.size() == 0)

{

return; // 處理完成,返回

}

else if(statement.substr(statement.size() - 1) == zero_string)

{

wstring tempstr = statement;

tempstr = tempstr.substr(0, tempstr.size() - 1);

ctx.set_statement(tempstr);

return;

}

else

{

vector<Expression*> stx_tree;

stx_tree.push_back(new GeExpression());

stx_tree.push_back(new ShExpression());

stx_tree.push_back(new BaExpression());

stx_tree.push_back(new QiExpression());

stx_tree.push_back(new WaExpression());

if(statement.substr(statement.size() - 1) == get_postfix())

{

int temp_data = ctx.get_data();

ctx.set_data(0);

statement = statement.substr(0, statement.size() - 1);

ctx.set_statement(statement);

for(vector<Expression*>::iterator it = stx_tree.begin(); it != stx_tree.end(); it++)

{

if(ctx.get_statement().size() == 0) break;

(*it)->Interpret(ctx);

}

ctx.set_data(temp_data + ctx.get_data() * Multiplier());

// 刪除語法樹中動態構造的元素,以免內存泄漏

for(vector<Expression*>::iterator it = stx_tree.begin(); it != stx_tree.end(); )

{

Expression *temp = *it;

it = stx_tree.erase(it);

delete temp;

}

return;

}

}

}

public:

~YiExpression()

{

cout << "in the destructor of YiExpression..." << endl;

}

};

// Interpreter.cpp

#include "Interpreter.h"

int main(int argc, char **argv)

{

wstring chinese_number = s2ws("一十九億零七百三十一萬六千八百三十九");

Context ctx(chinese_number);

vector<Expression*> stx_tree;

stx_tree.push_back(new GeExpression());

stx_tree.push_back(new ShExpression());

stx_tree.push_back(new BaExpression());

stx_tree.push_back(new QiExpression());

stx_tree.push_back(new WaExpression());

stx_tree.push_back(new YiExpression());

for(vector<Expression*>::iterator it = stx_tree.begin(); it != stx_tree.end(); it++)

{

(*it)->Interpret(ctx);

}

cout << ws2s(chinese_number) << " = " << ctx.get_data() << endl;

// 刪除語法樹中動態構造的元素,以免內存泄漏

for(vector<Expression*>::iterator it = stx_tree.begin(); it != stx_tree.end(); )

{

Expression *temp = *it;

it = stx_tree.erase(it);

delete temp;

}

return 0;

}

上述代碼運行結果:

in the destructor of GeExpression...

in the destructor of Expression...

in the destructor of ShExpression...

in the destructor of Expression...

in the destructor of BaExpression...

in the destructor of Expression...

in the destructor of QiExpression...

in the destructor of Expression...

in the destructor of GeExpression...

in the destructor of Expression...

in the destructor of ShExpression...

in the destructor of Expression...

in the destructor of BaExpression...

in the destructor of Expression...

in the destructor of QiExpression...

in the destructor of Expression...

in the destructor of WaExpression...

in the destructor of Expression...

一十九億零七百三十一萬六千八百三十九 = 1907316839

in the destructor of GeExpression...

in the destructor of Expression...

in the destructor of ShExpression...

in the destructor of Expression...

in the destructor of BaExpression...

in the destructor of Expression...

in the destructor of QiExpression...

in the destructor of Expression...

in the destructor of WaExpression...

in the destructor of Expression...

in the destructor of YiExpression...

in the destructor of Expression...

in the destructor of Context...

上述代碼對應靜態UML類圖:

18. C++實現Behavioral - Interpreter模式 - 玄機逸士 - 玄機逸士博客

上圖中GeExpressionShExpressionBaExpressionQiExpression均為Terminal ExpressionWaExpressionYiExpression均為Non-terminal Expression

上述程序的實際運算步驟:

"十九億零七百三十一萬六千八百三十九" ctx.data = 0

"十九億零七百三十一萬六千八百三十" ctx.data = 9

"十九億零七百三十一萬六千八百" ctx.data = 39

"十九億零七百三十一萬六千" ctx.data = 839

"十九億零七百三十一萬" ctx.data = 6839 (""去掉)

"十九億零七百三十一" ctx.data = 6839 ("零七百三十一"將遞歸地使用前面已有的Expression)

"十九億" ctx.data = 7316839 (""去掉)

ctx.data = 1907316839

posted on 2013-03-08 10:55 Jacc.Kim 閱讀(258) 評論(0)  編輯 收藏 引用 所屬分類: 設計模式
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美a级理论片| 欧美婷婷久久| 亚洲精品自在久久| 亚洲第一主播视频| 亚洲成人自拍视频| 日韩视频一区二区三区在线播放免费观看| 亚洲国产成人tv| 一区二区三区高清在线| 亚洲视频图片小说| 欧美在线不卡视频| 欧美国产先锋| 国产精品美女一区二区| 在线精品视频免费观看| 99re6这里只有精品视频在线观看 99re6这里只有精品 | 亚洲一区二区视频在线| 香蕉国产精品偷在线观看不卡| 久久亚洲捆绑美女| 亚洲精品乱码| 久久国产精品久久久| 欧美精品日韩一区| 国产一区二区三区在线观看精品| 亚洲第一页自拍| 亚洲欧美一区在线| 亚洲成在线观看| 亚洲欧美一区二区精品久久久| 欧美成人精品在线| 国产日韩欧美在线观看| 日韩午夜电影在线观看| 久久久欧美一区二区| 亚洲靠逼com| 欧美jizzhd精品欧美喷水 | 亚洲久久成人| 欧美在线一级va免费观看| 亚洲成色www8888| 欧美主播一区二区三区| 欧美激情久久久| 伊人久久成人| 欧美在线精品免播放器视频| 99亚洲伊人久久精品影院红桃| 久久人人97超碰人人澡爱香蕉| 欧美手机在线| 亚洲一本视频| 亚洲裸体俱乐部裸体舞表演av| 久久亚洲二区| 激情文学一区| 久久―日本道色综合久久| 亚洲天堂网在线观看| 欧美日韩亚洲一区在线观看| 日韩视频中文| 亚洲精品少妇网址| 一本色道久久综合狠狠躁篇的优点| 夜夜嗨网站十八久久| 亚洲日本成人在线观看| 久久久久久999| 好吊色欧美一区二区三区视频| 亚洲欧美另类综合偷拍| 日韩亚洲一区二区| 欧美图区在线视频| 亚洲午夜精品网| 亚洲视频日本| 国产午夜亚洲精品理论片色戒| 欧美一区在线看| 午夜一区不卡| 黄色欧美日韩| 欧美1区2区3区| 欧美第十八页| 在线亚洲国产精品网站| 亚洲一区二区精品在线| 国产精品久久影院| 欧美中文在线观看国产| 亚洲欧洲av一区二区三区久久| 国产精品日本欧美一区二区三区| 亚洲综合精品| 欧美一级成年大片在线观看| 国产曰批免费观看久久久| 久久综合九色综合久99| 欧美电影在线| 亚洲尤物在线视频观看| 亚洲欧美日韩国产另类专区| 国产自产女人91一区在线观看| 久久亚洲私人国产精品va媚药| 久久综合精品一区| 亚洲午夜激情| 久久er99精品| 99视频超级精品| 亚洲免费在线观看| 亚洲第一黄网| 一区二区三区四区五区精品| 国内精品久久久久伊人av| 欧美激情按摩| 国产精品欧美经典| 牛夜精品久久久久久久99黑人| 欧美激情偷拍| 久久综合99re88久久爱| 欧美日韩专区| 亚洲高清视频的网址| 国产精品久久亚洲7777| 欧美激情片在线观看| 国产麻豆精品视频| 91久久精品一区| 国产欧美日韩综合一区在线播放| 欧美国产免费| 国产情人节一区| 亚洲精品色婷婷福利天堂| 狠狠网亚洲精品| 亚洲一级影院| 日韩视频在线观看免费| 校园激情久久| 亚洲在线中文字幕| 欧美激情一区在线| 美女精品在线观看| 国产一区在线看| 亚洲欧美日本日韩| 久久精品亚洲精品国产欧美kt∨| 亚洲欧洲日韩综合二区| 国产情人节一区| 在线综合欧美| 亚洲精品影院| 久久亚洲春色中文字幕| 久久久久九九视频| 国产女主播一区二区| 中日韩男男gay无套| 久久国产精品一区二区三区四区| 国产性做久久久久久| 亚洲一级二级在线| 最新中文字幕亚洲| 国产亚洲欧洲一区高清在线观看 | 欧美在线免费视屏| 亚洲欧美日韩精品一区二区| 欧美成人精品一区二区| 欧美aⅴ一区二区三区视频| 国产日韩欧美| 久久激情视频| 久久久欧美精品| 激情视频亚洲| 老司机成人网| 亚洲高清资源综合久久精品| 亚洲人在线视频| 欧美另类在线播放| 亚洲高清视频一区二区| 日韩视频―中文字幕| 亚洲国产综合在线看不卡| 香蕉成人伊视频在线观看| 亚洲人妖在线| 一二三区精品福利视频| 美女日韩在线中文字幕| 免费亚洲一区二区| 亚洲国产精品女人久久久| 免费看成人av| 亚洲激情视频在线播放| 一区二区三区蜜桃网| 国产精品福利片| 亚洲欧美日韩一区在线| 久久精品视频99| 亚洲东热激情| 欧美日韩久久精品| 午夜国产精品影院在线观看| 久久午夜精品| 亚洲日韩欧美视频| 欧美看片网站| 国产精品综合久久久| 欧美一区二区三区精品电影| 蜜臀99久久精品久久久久久软件| 亚洲国产网站| 欧美激情一区二区在线| 亚洲男人天堂2024| 免费视频一区二区三区在线观看| 亚洲国产乱码最新视频| 国产精品草草| 久久精品日韩欧美| 一本一本a久久| 另类天堂av| 亚洲欧美在线x视频| 久久精品国产一区二区三区免费看| 国产亚洲精品久久久久动| 久久视频精品在线| 亚洲美女免费视频| 久久久精品视频成人| 日韩视频一区二区三区| 国产美女精品一区二区三区 | 欧美1区2区| 亚洲日韩欧美视频| 国产日韩在线一区| 美女黄毛**国产精品啪啪| 一本一本久久a久久精品综合麻豆| 久久精品国产久精国产爱| 亚洲精选在线观看| 狠狠干成人综合网| 国产乱人伦精品一区二区 | 欧美刺激性大交免费视频| 性做久久久久久久久| 亚洲美女少妇无套啪啪呻吟| 美女黄毛**国产精品啪啪| 亚洲欧美精品在线| 夜夜爽av福利精品导航| 亚洲激情欧美激情| 尹人成人综合网| 狠狠色丁香婷婷综合影院| 国产欧美日韩在线| 国产女主播在线一区二区|