• <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>

            積木

            No sub title

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

            常用鏈接

            留言簿(1)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            設計模式學習總結之二

            三:Singleton模式(單實例模式)

             顧名思義,即單例模式。其主要思想就是在項目中,僅創(chuàng)建一個實例對象。該對象的抽象,除了通過指定的獲取實例接口外,再沒其他辦法可以初始化。
            此可以保證整個系統(tǒng)生命周期內,僅會有一個實例存在。可以想象一下,它是可以與先前說的工廠模式或抽象工廠模式結合使用的。因為一般來說,工廠可能只會
            有一個(至少對某種邏輯處理來說是這樣的)。
             在C++中,實現單例模式,相對比較直觀及合理。將該實例定義成static成員即可。并提供獲取及釋放該成員的接口。而在delphi中,(就本來的了解來說)
            似乎并沒有直觀的靜態(tài)成員這一說法。但可以定義一個全局變量,并提供獲取與釋放變量的接口來模擬。(但,畢竟沒辦法同類型的實例被創(chuàng)建出來,所以最好要加
            詳細注釋說明。告知其他組員,此為單實例)

             參考的c++實現:
             class CA
             {
             private:
              CA(){}
             private:
              static CA* m_pAObj;
             public:
              virtual ~CA(){}
              static CA* GetAObj(void)
              {
               if (m_pAObj == NULL)
                m_pAObj = new CA();
               return m_pAObj;
              }
              static void SafeReleaseAObj(void)
              {
               if (m_pAObj != NULL)
                delete m_pAObj;
               m_pAObj = NULL;
              }
             };
             static CA* CA::m_pAObj = NULL;

             參考的Delphi實現:
             unit xxx
             interface
             uses
               xxx,...,yyy;
             type
               TMyClass = class
               //xxxx
               end;
             var
               gAObj: TMyClass;//此為全局的單實例對象。
             function GetAObj: TMyClass;
             procedure SafeReleaseAObj;
             implemention//這個單詞忘了是不是這么寫。反應是實現的那個單詞。。
             procedure SafeReleaseAObj;
             begin
               if Assigned(gAObj) then
                 FreeAndNil(gAObj);
             end;
             funciton GetAObj: TMyClass;
             begin
               if not Assigned(gAObj) then
                 gAObj = TMyClass.Create;
               Result := gAObj;
             end;

             //說明:以上僅是臨時寫的,并未在程序中編譯測試。但思路肯定不會錯。可供參考用。
             
            四:Builder模式(即:構建模式)

             往往在實際項目的開發(fā)過程中會發(fā)現,某些模塊的功能過于復雜。此時,我們自然就會想到將其進行進一步的劃分。如:細分成DA,DB,...,DN。然后由該模塊的某個管理角色進行協(xié)調運作。
            這樣,Builder模式將可用在此設計上。其思想,就是將復雜問題進一步細化。

            posted on 2011-05-15 15:31 Jacc.Kim 閱讀(298) 評論(0)  編輯 收藏 引用 所屬分類: 設計模式
            狠狠色丁香婷婷综合久久来来去 | 国产99久久久国产精品~~牛 | 久久精品国产乱子伦| 久久国产精品无| 国产综合久久久久久鬼色| 大美女久久久久久j久久| 99久久综合国产精品免费| 久久久无码精品亚洲日韩按摩| 国内精品久久九九国产精品| 蜜桃麻豆www久久国产精品| 久久99国产综合精品免费| 久久男人AV资源网站| 亚洲国产精品无码久久SM | 人妻少妇久久中文字幕一区二区| 久久久久国产精品| 女人高潮久久久叫人喷水| 日韩一区二区久久久久久| 亚洲欧美成人综合久久久| 亚洲乱亚洲乱淫久久| 日日噜噜夜夜狠狠久久丁香五月| 久久黄色视频| 999久久久免费国产精品播放| 97精品依人久久久大香线蕉97| 久久精品国产黑森林| 久久免费高清视频| 国内精品久久久久影院一蜜桃| 亚洲va久久久久| 久久天天躁狠狠躁夜夜2020老熟妇| 国产精品久久久久久福利69堂| 久久精品国产亚洲AV香蕉| 中文成人无码精品久久久不卡| 久久婷婷五月综合成人D啪| 久久99国产精一区二区三区| 成人妇女免费播放久久久| 亚洲精品乱码久久久久久蜜桃不卡| 久久婷婷五月综合成人D啪| 精品国产综合区久久久久久| 中文字幕亚洲综合久久2| 99久久精品无码一区二区毛片| 日本精品久久久中文字幕| 国产精品日韩深夜福利久久 |