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

            實時陰影繪制技術研究

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              48 Posts :: 20 Stories :: 57 Comments :: 0 Trackbacks
            from:http://www.pconline.com.cn/pcedu/empolder/gj/c/0407/421424.html

            ANSI C++ 中的 Singleton 實現(xiàn)說難不難,說容易也不容易,很多人寫 ANSI C++ 的 Singleton class 都有錯誤。這篇文章討論怎樣在 ANSI c++ 中寫 Singleton class, 希望對大家有幫助。

            ? 《設計模式》中把 Singleton 寫成返回指針:



            class Singleton{
            public:
            ??? static Singleton* Instance();
            protected:
            ??? Singleton();
            private:
            ??? static Singleton* _instance;
            };

            ????? 相應的實現(xiàn) cpp 文件是:


            Singleton* Singleton::_instance;
            Singleton* Singleton::Instance(){
            ??? if( _instance == 0){
            ??????? _instance = new Singleton;
            ??? };
            ??? return _instance;
            }

            ?

            ??? 將構(gòu)造函數(shù)設計成 protected 的目的是防止在 class 外面 new ,有人可能會設計成 private ,如果考慮到有可能會繼承這個類的話,還是將構(gòu)造函數(shù)設計成 protected 比較好,還需要加一個 virtual 析構(gòu)函數(shù)。為了防止別人復制 Singleton 對象:


            Singleton* pSingleton = Singleton::Instance();
            Singleton s1 = *pSingleton;
            Singleton s2 = *pSingleton;
            需要將拷貝構(gòu)造(copy constructor)函數(shù)變成 private。


            ??? 但是這里存在的問題是,什么時候刪除 Singleton 對象?按照 C++ 的一個基本原則,對象在哪里創(chuàng)建就在哪里銷毀,這里還應該放一個 destroy 方法來刪除 Singleton 對象。如果忘了刪除就比較麻煩。Instance 函數(shù)還存在多線程同時訪問的加鎖問題。如果把 Instance 函數(shù)開始和結(jié)尾放上加鎖和解鎖,整個函數(shù)性能會下降很多。這不是一個好的設計。
            ??? 有一個小小的改動,可以避免忘了刪除 Singleton 對象帶來內(nèi)存泄露的問題。那就是用 std:auto_ptr 來包含 Singleton 對象,定義一個class static member auto_ptr 對象,在析構(gòu)的靜態(tài) auto_ptr 變量的時候時候自動刪除 Singleton 對象。為了不讓用戶 delete Singleton 對象,需要將析構(gòu)函數(shù)由 public 變成 protected。以下是頭文件 SingletonAutoPtr.h :


            #include <memory>
            using namespace std;
            class CSingletonAutoPtr
            {
            private:
            ??? static auto_ptr<CSingletonAutoPtr> m_auto_ptr;

            posted on 2006-03-27 13:57 苦行僧 閱讀(1163) 評論(2)  編輯 收藏 引用 所屬分類: 轉(zhuǎn)載

            Feedback

            # re: C++ 中的Singleton 類的實現(xiàn)討論 2006-04-21 09:11 Stone Jiang
            當一個單體類引用另一個單體類的時候,在析構(gòu)時,還要多加小心.
              回復  更多評論
              

            # re: C++ 中的Singleton 類的實現(xiàn)討論 2006-04-22 05:56 苦行僧
            但是我理解singlton一般就像static變量一樣,很少作為一個對象的屬性,實現(xiàn)上singlton也是用static來實現(xiàn)的,應該都是最后退出程序的時候析構(gòu)吧。  回復  更多評論
              

            久久人人青草97香蕉| 欧美午夜精品久久久久免费视| 99久久婷婷国产综合亚洲| 久久精品国产亚洲av日韩| 青青青青久久精品国产| 久久一区二区三区免费| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 欧美激情精品久久久久久| 伊人久久大香线蕉成人| 久久91精品国产91久久户| 伊人久久精品影院| 91久久精品视频| 久久久久亚洲AV片无码下载蜜桃| 久久国产影院| 999久久久无码国产精品| 久久福利资源国产精品999| 欧美日韩中文字幕久久伊人| 亚洲精品无码久久久久去q| 久久久久久无码国产精品中文字幕 | 亚洲人成伊人成综合网久久久| 66精品综合久久久久久久| 亚洲精品乱码久久久久久| 久久青青草原亚洲av无码| 国产午夜久久影院| 久久精品亚洲精品国产色婷| 久久久国产99久久国产一| 久久精品国产精品亚洲| AAA级久久久精品无码区| 丁香五月网久久综合| 99久久免费国产精品热| 亚洲狠狠婷婷综合久久蜜芽 | 女人高潮久久久叫人喷水| 久久久久亚洲AV成人网| 久久国产V一级毛多内射| 99久久亚洲综合精品成人| 女人香蕉久久**毛片精品| 久久国产乱子伦精品免费强| 国产韩国精品一区二区三区久久| 国产产无码乱码精品久久鸭 | 一本久久免费视频| 国产香蕉久久精品综合网|