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

積木

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模式 - 玄機逸士 - 玄機逸士博客

上圖中GeExpression、ShExpression、BaExpressionQiExpression均為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 閱讀(262) 評論(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>
            国产欧美91| 欧美制服丝袜| 久久久夜精品| 午夜精品亚洲| 国产精品都在这里| 亚洲风情在线资源站| 国产一区二区三区高清在线观看| 一区二区国产在线观看| 亚洲人成网站在线观看播放| 久久国产精品久久精品国产| 欧美一级久久| 国产精品久久久久aaaa| 亚洲精品无人区| 亚洲人屁股眼子交8| 免费不卡中文字幕视频| 久久综合国产精品台湾中文娱乐网| 国产精品美女久久| 亚洲一区二区高清| 亚洲欧美制服中文字幕| 欧美视频1区| 亚洲视频观看| 欧美一区二区视频网站| 国产精品丝袜91| 亚洲欧美在线另类| 欧美夜福利tv在线| 国产亚洲在线观看| 欧美在线999| 老鸭窝毛片一区二区三区| 激情欧美一区二区| 狂野欧美一区| 亚洲精品婷婷| 亚洲欧美日本伦理| 国产欧美日韩视频一区二区三区| 午夜精品久久久久久久| 欧美中文字幕久久| 狠狠干狠狠久久| 毛片av中文字幕一区二区| 亚洲国产激情| 亚洲欧美区自拍先锋| 国产欧美日韩中文字幕在线| 香蕉久久久久久久av网站| 老司机午夜精品视频在线观看| 亚洲国产精品久久久久| 欧美区在线观看| 在线亚洲欧美| 美国十次成人| 99re视频这里只有精品| 欧美日韩极品在线观看一区| 亚洲特级片在线| 久久久人人人| 99精品久久久| 国产欧美日韩视频在线观看| 久久综合九色综合欧美就去吻| 亚洲人永久免费| 欧美一区二区三区四区在线| 在线成人h网| 欧美日韩专区| 久久美女性网| 一区二区三区国产盗摄| 久久午夜激情| 亚洲无限av看| 国产一区二区三区久久| 欧美黄色免费网站| 欧美一区二区三区四区视频 | 最新成人av在线| 国产精品国产三级国产| 久久只有精品| 午夜久久电影网| 亚洲区第一页| 看片网站欧美日韩| 亚洲中午字幕| 亚洲国产一区二区三区青草影视| 国产精品日韩欧美一区二区| 奶水喷射视频一区| 欧美一区免费视频| 日韩视频在线观看国产| 久久久噜噜噜久噜久久| 亚洲天堂av综合网| 亚洲高清在线| 黑人操亚洲美女惩罚| 国产精品v日韩精品| 欧美1级日本1级| 欧美一区二区免费视频| 一区二区三区高清视频在线观看| 亚洲大片精品永久免费| 久久久久久电影| 欧美一区二区黄| 一区二区三区日韩| 亚洲精品乱码久久久久久日本蜜臀| 国产亚洲欧美一区二区三区| 国产精品二区在线观看| 欧美另类一区| 欧美顶级艳妇交换群宴| 久久久久久一区二区三区| 香蕉免费一区二区三区在线观看 | aa亚洲婷婷| 亚洲国产高清一区二区三区| 久久夜色精品国产亚洲aⅴ| 欧美在线亚洲综合一区| 亚洲女人av| 午夜在线电影亚洲一区| 亚洲欧美国产视频| 亚洲综合精品一区二区| 亚洲一区尤物| 亚洲伊人一本大道中文字幕| 亚洲一区二区黄| 亚洲午夜在线| 亚洲自拍三区| 午夜久久久久久| 欧美一区二区三区的| 午夜精品视频在线| 欧美影院久久久| 久久久久久网| 欧美黄色一区二区| 亚洲激情视频在线播放| 亚洲精品视频在线观看免费| 99视频超级精品| 亚洲综合电影一区二区三区| 午夜亚洲激情| 久久―日本道色综合久久| 欧美aⅴ99久久黑人专区| 欧美激情按摩在线| 国产精品久久久999| 国产日本欧洲亚洲| 亚洲国产裸拍裸体视频在线观看乱了中文| 亚洲福利视频一区| 日韩一级免费| 欧美在线视频二区| 欧美国产大片| 日韩一级大片| 欧美亚洲综合久久| 欧美.www| 国产精品你懂的在线欣赏| 狠狠久久亚洲欧美专区| 亚洲精品小视频| 欧美一区二区在线播放| 免费观看亚洲视频大全| 亚洲精品一二三区| 欧美一区二区三区的| 米奇777超碰欧美日韩亚洲| 欧美日韩亚洲国产精品| 国语自产精品视频在线看抢先版结局 | 男人插女人欧美| 99国产精品久久久久久久久久| 亚洲欧美在线aaa| 欧美大片18| 国产在线不卡精品| 一区二区欧美日韩| 久久蜜桃精品| 亚洲桃色在线一区| 欧美大片免费观看| 国产一区二区三区在线观看视频| 日韩一级黄色大片| 裸体一区二区三区| 制服丝袜激情欧洲亚洲| 蜜桃伊人久久| 国产一区二区激情| 亚洲一区免费观看| 欧美激情网站在线观看| 午夜精品视频在线观看| 欧美日韩亚洲91| 亚洲人成在线播放网站岛国| 久久精品30| 亚洲视频香蕉人妖| 欧美精品久久一区二区| 激情久久五月天| 久久成人免费日本黄色| 99pao成人国产永久免费视频| 久久久久久久综合日本| 国产日韩精品电影| 亚洲淫性视频| 一区二区免费在线播放| 欧美国产专区| 91久久国产自产拍夜夜嗨 | 欧美一级艳片视频免费观看| 亚洲精品在线三区| 欧美~级网站不卡| 亚洲大胆视频| 久久五月激情| 欧美一区二区三区的| 国产美女精品人人做人人爽| 亚洲尤物视频网| 在线视频你懂得一区二区三区| 欧美日韩亚洲一区| 亚洲精品一二区| 亚洲黄网站黄| 欧美精品一区视频| 最新成人av在线| 亚洲国产精品高清久久久| 免费成年人欧美视频| 亚洲国产精品久久久久久女王| 免费精品视频| 欧美成人午夜影院| 亚洲美洲欧洲综合国产一区| 91久久夜色精品国产九色| 欧美经典一区二区三区| 亚洲图片在线| 在线一区二区三区四区| 国产精品日韩欧美大师| 久久激情视频免费观看|