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

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

二、結構
Strategy模式的結構如下圖所示:

 
從結構上看,Strategy模式與State模式有幾分相似,但二者所討論的Context(情景)具有顯著的差異:
State模式在于將其狀態信息分離出來保存到一個獨立的對象中,以便狀態信息的獲取或狀態的轉換;Strategy模式在于將可能的算法分離出來,根據需要進行適當的選擇。此外,二者的區別還在于,Strategy模式中各個Strategy(算法、策略)往往用于解決相同的問題,即只是解決同一問題的不同“策略”、“途徑”,而且,一次只能有一個Strategy為上次應用提供服務;而State模式中的各個State本身往往具有一定的差異,但他們之間存在明顯的相互轉換的關系,而且這種轉換往往會在程序運行過程中經常性地發生,同時存在一個以上State也是可能的。

區別參考:二者的應用場合不同。狀態模式用于處理對象有不同狀態(狀態機)的場合,策略模式用于隨不同外部環境采取不同行為的場合。在狀態模式中,狀態的變遷是由對象的內部條件決定,外界只需關心其接口,不必關心其狀態對象的創建和轉化;而策略模式里,采取何種策略由外部條件決定。所以,有人說“狀態模式是完全封裝且自修改的策略模式”。至于Bridge,在結構上與前兩者都不一樣了。要說相似之處,就是三者都有具有對外接口統一的類,展現出多態性而已。

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

四、舉例
下面是一個應用Strategy模式對vector進行排序的例子,為了簡化問題,其中的排序Strategy實際上調用的是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 }

本文轉自:http://blog.csdn.net/haiyan0106/article/details/1651797
posted on 2012-07-17 08:11 王海光 閱讀(601) 評論(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>
            久久久精品免费视频| 亚洲四色影视在线观看| 久久精品国产免费| 国产精品狼人久久影院观看方式| 亚洲欧美国产高清| 久热精品在线| 一区二区三区精品视频| 亚洲欧美韩国| 亚洲乱码视频| 久久久国产成人精品| 亚洲一区二区成人在线观看| 一本综合精品| 亚洲一区二区三区欧美| 亚洲视频免费在线观看| 亚洲性感激情| 久久国产精品72免费观看| 久久久久久久国产| 欧美韩日精品| 国产精品麻豆欧美日韩ww| 韩日欧美一区二区| 亚洲毛片一区二区| 欧美亚洲视频在线看网址| 欧美成人性生活| a91a精品视频在线观看| 欧美在线日韩精品| 欧美日韩国产色站一区二区三区| 国产精品一区二区三区免费观看| 一区三区视频| 老司机午夜精品视频| 美腿丝袜亚洲色图| 噜噜爱69成人精品| 亚洲精品综合精品自拍| 久久爱另类一区二区小说| 美女日韩欧美| 国产精品视频精品| 亚洲精品一区二区三区樱花| 久久成人综合视频| 亚洲美女网站| 麻豆成人在线播放| 国产日韩一区二区| 亚洲夜间福利| 亚洲国产欧美一区二区三区同亚洲| 亚洲精品激情| 久久久久久夜精品精品免费| 国产精品美女久久久久av超清| 亚洲国产精品尤物yw在线观看| 香蕉精品999视频一区二区 | 久久夜色精品| 国产欧美91| 亚洲曰本av电影| 亚洲高清不卡| 久久久亚洲一区| 国产色爱av资源综合区| 午夜一区在线| 99国内精品久久| 欧美高清在线视频观看不卡| 影音先锋中文字幕一区二区| 欧美呦呦网站| 亚洲综合欧美日韩| 国产精品二区在线观看| 亚洲大黄网站| 欧美精品一区二区三区视频| 亚洲国产欧美日韩精品| 免费成人美女女| 久久久久久一区二区三区| 一区二区在线免费观看| 免费在线观看一区二区| 久久阴道视频| 亚洲人体影院| 日韩一级精品| 国产精品视频免费观看www| 午夜日韩福利| 小嫩嫩精品导航| 国产亚洲福利| 麻豆免费精品视频| 欧美国产视频日韩| 亚洲一区在线直播| 午夜在线精品| 亚洲国产精品va在线观看黑人| 亚洲国产成人精品久久| 欧美日韩综合视频网址| 欧美亚洲综合在线| 久久精品中文字幕免费mv| 亚洲国产mv| 99re视频这里只有精品| 国产精品天美传媒入口| 美女久久一区| 欧美激情视频给我| 午夜国产一区| 老司机精品久久| 亚洲一区在线看| 久久精品天堂| 亚洲视频一二| 欧美一级欧美一级在线播放| 亚洲黄色尤物视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 国产精品美女久久久| 久久婷婷国产综合精品青草| 欧美h视频在线| 西瓜成人精品人成网站| 久久一二三四| 午夜精品一区二区三区在线视 | 欧美日韩精品欧美日韩精品 | 亚洲黄色免费网站| 国产精品嫩草影院av蜜臀| 另类综合日韩欧美亚洲| 欧美偷拍另类| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美日本一区二区视频在线观看| 欧美一乱一性一交一视频| 欧美经典一区二区三区| 开元免费观看欧美电视剧网站| 欧美国产日本韩| 久久精品视频在线看| 欧美日韩视频在线一区二区| 嫩草成人www欧美| 欧美人与性动交a欧美精品| 久久国产精品久久w女人spa| 狂野欧美性猛交xxxx巴西| 亚洲欧美视频在线| 欧美精品观看| 欧美激情中文字幕一区二区| 国内精品国语自产拍在线观看| 欧美黄色成人网| 亚洲欧美中文日韩在线| 欧美激情亚洲综合一区| 可以看av的网站久久看| 国产日本亚洲高清| 国产精品99久久99久久久二8| 亚洲毛片播放| 欧美激情按摩| 亚洲欧洲日韩在线| 亚洲蜜桃精久久久久久久| 男女激情久久| 国产有码一区二区| 一区二区三区高清不卡| 亚洲一区二区免费看| 欧美视频不卡| 99国产精品久久| 亚洲一区二区在线| 国产精品久久亚洲7777| 亚洲在线国产日韩欧美| 欧美一区二区三区的| 国产日韩一区二区三区在线| 欧美在现视频| 欧美.com| 99热这里只有精品8| 欧美色图一区二区三区| 亚洲一区二区动漫| 久久久人成影片一区二区三区观看 | 欧美专区亚洲专区| 国产一区久久| 久久久中精品2020中文| 欧美国产先锋| 一区二区欧美激情| 国产精品视区| 久久国产主播| 欧美激情视频网站| 一区二区三区国产精品| 国产乱码精品一区二区三| 久久九九热re6这里有精品| 欧美 日韩 国产一区二区在线视频| 91久久精品网| 欧美亚韩一区| 久久精品一本| 亚洲精品在线看| 久久国内精品自在自线400部| 亚洲福利视频在线| 欧美精品一区二区三区四区| 亚洲一级黄色片| 免费在线一区二区| 亚洲天堂视频在线观看| 激情偷拍久久| 欧美日韩一区二区在线视频| 欧美在线精品一区| 亚洲欧洲一区二区在线播放| 午夜精品久久久久久久99水蜜桃 | 亚洲一二三区精品| 国产一区二区日韩| 女人香蕉久久**毛片精品| 夜夜夜精品看看| 免费亚洲电影| 午夜视频久久久久久| 最新国产乱人伦偷精品免费网站| 国产精品国产三级国产专播品爱网| 久久狠狠婷婷| 亚洲深夜影院| 亚洲人成网站色ww在线| 久久婷婷蜜乳一本欲蜜臀| 一区二区三区欧美视频| 亚洲国产成人av在线| 国产区二精品视| 欧美日韩八区| 欧美国产大片| 久久夜色精品国产亚洲aⅴ| 亚洲女同在线| 一区二区三区四区国产精品| 亚洲国产影院| 欧美成人免费在线视频| 久久久久国色av免费观看性色|