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

面對(duì)現(xiàn)實(shí),超越自己
逆水行舟,不進(jìn)則退
posts - 269,comments - 32,trackbacks - 0
一、概述
Strategy(策略)模式又稱Policy模式,用于定義一系列的算法,把它們一個(gè)個(gè)封裝起來(lái),并且使它們可相互替換。這里的算法并非狹義的數(shù)據(jù)結(jié)構(gòu)或算法理論中所討論的KMP、shell sort等算法,而是指應(yīng)用程序設(shè)計(jì)中不同的處理邏輯,前面所說(shuō)的狹義的算法只是其中的一部分。Strategy模式使得算法與算法的使用者相分離,減少了二者間的耦合度,使得算法可獨(dú)立于使用它的客戶而變化;同時(shí),由于設(shè)計(jì)粒度的減小,程序的復(fù)用性也得到了進(jìn)一步提高,分離出來(lái)的算法可以更好地適應(yīng)復(fù)用的需要。

二、結(jié)構(gòu)
Strategy模式的結(jié)構(gòu)如下圖所示:

 
從結(jié)構(gòu)上看,Strategy模式與State模式有幾分相似,但二者所討論的Context(情景)具有顯著的差異:
State模式在于將其狀態(tài)信息分離出來(lái)保存到一個(gè)獨(dú)立的對(duì)象中,以便狀態(tài)信息的獲取或狀態(tài)的轉(zhuǎn)換;Strategy模式在于將可能的算法分離出來(lái),根據(jù)需要進(jìn)行適當(dāng)?shù)倪x擇。此外,二者的區(qū)別還在于,Strategy模式中各個(gè)Strategy(算法、策略)往往用于解決相同的問(wèn)題,即只是解決同一問(wèn)題的不同“策略”、“途徑”,而且,一次只能有一個(gè)Strategy為上次應(yīng)用提供服務(wù);而State模式中的各個(gè)State本身往往具有一定的差異,但他們之間存在明顯的相互轉(zhuǎn)換的關(guān)系,而且這種轉(zhuǎn)換往往會(huì)在程序運(yùn)行過(guò)程中經(jīng)常性地發(fā)生,同時(shí)存在一個(gè)以上State也是可能的。

區(qū)別參考:二者的應(yīng)用場(chǎng)合不同。狀態(tài)模式用于處理對(duì)象有不同狀態(tài)(狀態(tài)機(jī))的場(chǎng)合,策略模式用于隨不同外部環(huán)境采取不同行為的場(chǎng)合。在狀態(tài)模式中,狀態(tài)的變遷是由對(duì)象的內(nèi)部條件決定,外界只需關(guān)心其接口,不必關(guān)心其狀態(tài)對(duì)象的創(chuàng)建和轉(zhuǎn)化;而策略模式里,采取何種策略由外部條件決定。所以,有人說(shuō)“狀態(tài)模式是完全封裝且自修改的策略模式”。至于Bridge,在結(jié)構(gòu)上與前兩者都不一樣了。要說(shuō)相似之處,就是三者都有具有對(duì)外接口統(tǒng)一的類,展現(xiàn)出多態(tài)性而已。

三、應(yīng)用
當(dāng)存在以下情況時(shí)可考慮使用Strategy模式:
1.
許多相關(guān)的類僅僅是行為有異。“策略”提供了一種用多個(gè)行為中的一個(gè)行為來(lái)配置一個(gè)類的方法。
2.
需要使用一個(gè)算法的不同變體。例如,你可能會(huì)定義一些反映不同的空間/時(shí)間權(quán)衡的算法,當(dāng)這些變體實(shí)現(xiàn)為一個(gè)算法的類層次時(shí),可以使用策略模式。
3.
算法使用客戶不應(yīng)該知道的數(shù)據(jù)。可使用策略模式以避免暴露復(fù)雜的、與算法相關(guān)的數(shù)據(jù)結(jié)構(gòu)。
4.
一個(gè)類定義了多種行為,并且這些行為在這個(gè)類的操作中以多個(gè)條件語(yǔ)句的形式出現(xiàn)。將相關(guān)的條件分支移入它們各自的Strategy類中以代替這些條件語(yǔ)句。
更具體的應(yīng)用實(shí)例包括:
1.
以不同的格式保存文件;
2.
以不同的方式對(duì)文件進(jìn)行壓縮或其他處理;
3.
以不同的方式繪制/處理相同的圖形數(shù)據(jù);
等等。

四、舉例
下面是一個(gè)應(yīng)用Strategy模式對(duì)vector進(jìn)行排序的例子,為了簡(jiǎn)化問(wèn)題,其中的排序Strategy實(shí)際上調(diào)用的是STL的排序算法:sort和stable_sort。
  1 #include <iostream>
  2 #include <vector>
  3 #include <algorithm>
  4 #include <time.h>
  5 using namespace std;
  6 
  7 template <typename T>
  8 class SortStrategy    // Strategy
  9 {
 10 public:
 11     virtual void Sort( vector<T>& v_t ) = 0;
 12 };
 13 
 14 template <typename T>
 15 class SortQuick : public SortStrategy<T>    // ConcreateStrategy1
 16 {
 17 public:
 18     void Sort( vector<T>& v_t ) { std::sort( v_t.begin(), v_t.end() ); }
 19 };
 20 
 21 template <typename T>
 22 class SortStable : public SortStrategy<T>    // ConcreateStrategy1
 23 {
 24 public:
 25     void Sort( vector<T>& v_t ) { std::stable_sort(v_t.begin(), v_t.end()); }
 26 };
 27 
 28 template <typename T>
 29 class Context {        // Context, who or whose client takes charge of which strategy will be selected
 30 public:
 31     Context() { m_pStrategy = NULL; }
 32     virtual ~Context() { if (m_pStrategy != NULL) delete m_pStrategy; }
 33 
 34     void SetStrategy(SortStrategy<T>* pStrategy);    // select a strategy
 35 
 36     void ReadVector( vector<T>& v_t);
 37     bool SortVector();
 38     void OutputVector();
 39 private:
 40     vector<T> m_vt;
 41     SortStrategy<T>*  m_pStrategy;    // a pointer to current strategy
 42 };
 43 
 44 template <typename T>
 45 void Context<T>::SetStrategy( SortStrategy<T>* pStrategy )
 46 {
 47     if ( NULL != m_pStrategy )
 48         delete m_pStrategy;
 49 
 50     m_pStrategy = pStrategy;
 51 }
 52 
 53 template <typename T>
 54 void Context<T>::ReadVector( vector<T>& v_t)
 55 {
 56     m_vt.clear();
 57     copy( v_t.begin(), v_t.end(), back_inserter( m_vt ) );
 58 }
 59 
 60 template <typename T>
 61 bool Context<T>::SortVector()
 62 {
 63     if ( NULL == m_pStrategy )
 64         return false;
 65 
 66     m_pStrategy->Sort( m_vt );
 67 
 68     return true;
 69 }
 70 
 71 template <typename T>
 72 void Context<T>::OutputVector()
 73 {
 74     copy( m_vt.begin(), m_vt.end(), ostream_iterator<T>( cout, " " ) );
 75 }
 76 
 77 // a functor to generate random int
 78 struct RandGen
 79 {
 80     RandGen(int ratio) { m_ratio = ratio; }
 81     int operator() () { return rand() % m_ratio + 1; }
 82 private:
 83     int m_ratio;
 84 };
 85 
 86 int main()
 87 {
 88     const int NUM = 9;
 89     vector< int > vi;
 90     time_t t;
 91     srand( (unsigned) time(&t) );
 92 
 93     // create a vector with random information
 94     vi.reserve(NUM + 1);
 95     generate_n(back_inserter(vi), NUM, RandGen(NUM));
 96 
 97     Context< int >  con;
 98     con.SetStrategy( new SortQuick<int>() );
 99     con.ReadVector( vi );
100     con.OutputVector();
101 
102     cout << endl;
103 
104     con.SortVector();
105     con.OutputVector();
106 
107     return 0;
108 }

本文轉(zhuǎn)自:http://blog.csdn.net/haiyan0106/article/details/1651797
posted on 2012-07-17 08:11 王海光 閱讀(601) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Design Pattern
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            免费精品99久久国产综合精品| 国产精品久久久久久久久久ktv| 亚洲精品视频在线观看免费| 欧美成人日本| 亚洲盗摄视频| 亚洲三级影片| 正在播放亚洲| 久久gogo国模裸体人体| 久久免费高清| 欧美国产专区| 国产精品视频免费一区| 精品粉嫩aⅴ一区二区三区四区| 亚洲电影中文字幕| 一区二区毛片| 久久精品99久久香蕉国产色戒| 久久精品国产精品亚洲| 欧美激情第8页| 中日韩高清电影网| 久久亚洲不卡| 国产精品国产一区二区| 精品动漫3d一区二区三区免费版 | 性做久久久久久久久| 欧美专区在线播放| 欧美日韩国产电影| 国产综合激情| 亚洲午夜久久久| 欧美大色视频| 欧美在线视频a| 欧美日韩精品久久| 亚洲大胆美女视频| 欧美一区二区三区在线视频| 欧美国产日韩亚洲一区| 亚洲欧美另类中文字幕| 欧美日韩福利视频| 亚洲国产欧美国产综合一区| 欧美制服丝袜| 夜夜精品视频一区二区| 另类激情亚洲| 黄色一区二区三区| 欧美在线免费播放| 亚洲影院一区| 久久综合免费视频影院| 久久久久久夜| 国产精品v欧美精品∨日韩| 欧美国产视频一区二区| 欧美mv日韩mv国产网站| 欧美电影美腿模特1979在线看| 亚洲欧洲偷拍精品| 久久精品国产在热久久 | 国产最新精品精品你懂的| 一区二区精品国产| 欧美激情免费观看| 久久免费精品视频| 激情综合电影网| 米奇777超碰欧美日韩亚洲| 亚洲欧美一区二区三区极速播放| 欧美婷婷久久| 亚洲欧美日韩在线不卡| 亚洲视频图片小说| 欧美亚洲第一页| 香蕉久久一区二区不卡无毒影院| 亚洲精品乱码久久久久久黑人| 美女成人午夜| 亚洲精品美女久久7777777| 亚洲第一区在线| 欧美另类极品videosbest最新版本| 亚洲国产视频直播| 亚洲免费av观看| 国产精品高潮呻吟视频| 欧美一区二区观看视频| 亚洲一区二区三区精品视频| 国产精品日韩精品欧美精品| 欧美中文字幕第一页| 久久se精品一区二区| 在线成人国产| 亚洲人成网在线播放| 欧美日韩在线观看一区二区| 亚洲三级视频| 欧美精品在线极品| 亚洲视频网站在线观看| 一区二区免费在线视频| 国产精品免费在线| 久久免费高清| 欧美 日韩 国产 一区| 亚洲视频中文字幕| 亚洲女人av| 国内精品久久久久影院色| 麻豆久久婷婷| 欧美日韩一区二区在线视频 | 国产精品久久久久av免费| 欧美在线不卡视频| 久久影院午夜片一区| 一区二区三区不卡视频在线观看| 亚洲一区二区四区| 亚洲高清一区二| 在线亚洲高清视频| 狠狠色综合色区| aaa亚洲精品一二三区| 国产欧美一区视频| 91久久亚洲| 韩国一区二区三区在线观看| 亚洲日本欧美天堂| 国外视频精品毛片| 一区二区三区欧美视频| 亚洲电影av在线| 亚洲一区在线免费| 亚洲精品资源| 久久久久久色| 欧美影院视频| 欧美日韩精品福利| 欧美电影在线| 黄色一区二区三区四区| 亚洲伊人一本大道中文字幕| 亚洲精选一区二区| 久久久久久久网| 欧美影院午夜播放| 国产精品久久久久77777| 91久久精品国产91性色tv| 国内精品久久久久久影视8| 亚洲视频1区2区| 一本一道久久综合狠狠老精东影业 | 女仆av观看一区| 久久久欧美精品| 国产精品午夜av在线| 99精品免费| 99视频一区| 欧美精品久久99久久在免费线| 久久综合色影院| 国模套图日韩精品一区二区| 亚洲一区日本| 欧美一区二区私人影院日本| 欧美亚州韩日在线看免费版国语版| 亚洲国产aⅴ天堂久久| 亚洲黄色av一区| 欧美成人dvd在线视频| 欧美成人免费视频| 亚洲国产精品一区| 亚洲激情在线观看| 亚洲无毛电影| 亚洲欧美成人| 欧美成人国产一区二区| 久久久国产成人精品| 欧美日韩在线另类| 亚洲大片一区二区三区| 国模精品一区二区三区| 一区二区三区久久久| 亚洲精品国产精品乱码不99 | 久久爱www久久做| 欧美日韩999| 亚洲电影激情视频网站| 国内偷自视频区视频综合| 一本色道久久88综合日韩精品| 亚洲日本va午夜在线电影 | 午夜伦欧美伦电影理论片| 一区二区三区成人精品| 欧美大片一区二区| 欧美激情 亚洲a∨综合| 在线观看视频亚洲| 久久久久久亚洲精品不卡4k岛国| 亚洲欧美在线看| 欧美体内she精视频| 日韩亚洲一区在线播放| 亚洲一区亚洲| 黄色av成人| 欧美精品一区二区三区视频 | 91久久香蕉国产日韩欧美9色| 亚洲成人资源网| 亚洲综合欧美日韩| 国产精品国产一区二区| 欧美伊人久久久久久午夜久久久久 | 免费日韩一区二区| 亚洲网站在线观看| 韩日成人av| 欧美国产综合一区二区| 亚洲视频国产视频| 美女视频黄a大片欧美| 一区二区三区日韩欧美精品| 国产午夜亚洲精品理论片色戒| 嫩草国产精品入口| 欧美亚洲综合另类| 一本大道久久a久久综合婷婷| 久久亚洲精品一区二区| 亚洲一级黄色片| 亚洲激情在线观看| 国产一区二区三区四区hd| 欧美精品在欧美一区二区少妇| 小黄鸭精品aⅴ导航网站入口| 亚洲精品小视频在线观看| 免费高清在线一区| 欧美一区二区在线免费观看| 一本久久综合亚洲鲁鲁五月天 | 亚洲伊人久久综合| 亚洲激情在线激情| 激情综合自拍| 国产欧美一二三区| 国产精品第三页| 欧美日韩国产综合视频在线| 麻豆乱码国产一区二区三区| 国产美女搞久久| 男人的天堂亚洲|