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

            愛老婆,要比編程多一點...

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              18 Posts :: 0 Stories :: 84 Comments :: 0 Trackbacks

            公告

            沐楓的個人主頁

            eoool.com生成

            eoool.com生成

            常用鏈接

            留言簿(8)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 56908
            • 排名 - 402

            最新評論

            閱讀排行榜

            評論排行榜

            .NET的類可以用 sealed 關(guān)鍵字來說明一個類是最終類,也就是說不能作為基類,不能被繼承。Java也有個相同的關(guān)鍵字final完成同樣的功能。這個功能有時候很有用。但是C++沒有這個關(guān)鍵字。那如何在C++中實現(xiàn)類似的功能呢?

            如何實現(xiàn)不可繼承的類      沐楓網(wǎng)志

            曾經(jīng)在CUJ上看到一篇文章介紹過一個方法,但具體網(wǎng)址已經(jīng)忘記了,Sorry。但是方法卻記下來了。它用一個私有的虛基類來實現(xiàn)。
            我在這種方法的基礎(chǔ)上,作了一個通用的工具類:Sealed,只要以此類為基類,那么該類就不可被繼承。為了進行性能優(yōu)化,在Release版本中,還將Sealed作成一個空類。

            Sealed類的實現(xiàn)如下:

            #ifdef _DEBUG
            namespace internalSealed 

                    
            class Class_Is_Sealed 
                    { 
                    
            protected
                            Class_Is_Sealed(){}
                    }; 
                    
            #ifndef _MSC_VER
                    template 
            <class T>
                    
            class typewrapper
                    {
                    
            public:
                          typedef T type;
                    };
            #endif
            }; 

            template 
            <typename T>
            class Sealed: private virtual internalSealed::Class_Is_Sealed 

            #ifdef _MSC_VER
                    friend T;
            #else
                    friend 
            class internalSealed::typewrapper<T>::type;
            #endif

            }; 
            #else
            template <typename T>
            class Sealed
            {
            };
            #endif

            這樣子,在Debug方式下,只要一個類從Sealed繼承,就不可再被繼承了。
            同時,在Release方式下,因為不再檢查是否可以被繼承,因而不產(chǎn)生開銷(空類會被編譯器優(yōu)化掉)。

            使用例子:

            #include "Sealed.h" 

            class test: Sealed <test>

            public
                    
            int print() 
                    

                            
            return 1
                    }
             
            }


            class ttt: public test 

            public
                    
            int print() 
                    

                            
            return 2
                    }
             
            }


            int main(int argc, char* argv[]) 

                    test t; 
                    printf(
            "%d\n", t.print()); 

                    ttt t1;   
            // 編譯錯誤
                    printf("%d\n", t1.print());  

                    
            return 0
            }
             


            posted on 2005-09-08 14:39 沐楓 閱讀(1784) 評論(6)  編輯 收藏 引用 所屬分類: C++

            Feedback

            # re: 如何實現(xiàn)不可繼承的類 2005-09-08 18:45 idior
            好像應(yīng)該利用vitual關(guān)鍵字和構(gòu)造析構(gòu)函數(shù)配合的  回復(fù)  更多評論
              

            # re: 如何實現(xiàn)不可繼承的類 2005-09-08 22:42 路程
            謝謝  回復(fù)  更多評論
              

            # re: 如何實現(xiàn)不可繼承的類 2006-02-25 14:41 gogoplayer
            Debug和Release均不報錯,為何?我用VS6+win2K  回復(fù)  更多評論
              

            # re: 如何實現(xiàn)不可繼承的類 2006-02-27 13:31 沐楓網(wǎng)志
            對不起,我目前沒有用VS6,沒辦法幫你試。
            隨筆的代碼在VC7.0/VC7.1以及dev-cpp(4.998)所帶的c++編譯器上編譯通過。  回復(fù)  更多評論
              

            # re: 如何實現(xiàn)不可繼承的類 2006-03-22 14:46 sunny_98
            這個方法在VC7下有些問題:
            如果將上面文章中的main函數(shù)用如下代碼替換,將不會有編譯錯誤出現(xiàn):


            class use_ttt
            {
            public:
            test t;
            ttt t1;
            };
            int _tmain(int argc, _TCHAR* argv[])
            {
            // test t;
            use_ttt ut;
            ut.t.print();
            ut.t1.print();
            // printf("%d\n", t.print());

            // ttt t1; // 編譯錯誤
            // printf("%d\n", t1.print());

            return 0;
            }
              回復(fù)  更多評論
              

            # re: 如何實現(xiàn)不可繼承的類 2006-03-22 16:14 沐楓
            @sunny_98

            謝謝指出。我在vc2005下試,成功報錯。改天我在vc7.1下再試試。  回復(fù)  更多評論
              

            久久久无码精品亚洲日韩按摩 | 精品久久久久久无码免费| 亚洲AV无码久久| 久久这里只有精品首页| 亚洲人成无码www久久久| 国产—久久香蕉国产线看观看 | 天天综合久久一二三区| 日本精品久久久久久久久免费| 激情久久久久久久久久| 久久精品无码免费不卡| 中文字幕久久精品| 久久精品国产AV一区二区三区| 久久精品国产亚洲av麻豆图片| 亚洲七七久久精品中文国产 | 99久久精品国产一区二区 | 亚洲日本va午夜中文字幕久久| 欧美大战日韩91综合一区婷婷久久青草| 国产精品美女久久久久av爽| 九九久久精品无码专区| 婷婷久久五月天| 久久久久亚洲av无码专区喷水| 亚洲天堂久久精品| 老司机午夜网站国内精品久久久久久久久 | 久久亚洲中文字幕精品一区| 国产99久久久国产精品小说| 中文精品久久久久人妻不卡| AV色综合久久天堂AV色综合在| 国产成人久久久精品二区三区 | 久久成人精品视频| 欧美粉嫩小泬久久久久久久| 99久久99久久精品国产片果冻| 91精品国产9l久久久久| 蜜臀久久99精品久久久久久| 国产精品久久久久…| 午夜肉伦伦影院久久精品免费看国产一区二区三区| 中文精品99久久国产 | 久久人人爽人人爽人人片AV不| 亚洲天堂久久精品| 久久久噜噜噜久久熟女AA片| 久久久久人妻精品一区三寸蜜桃 | 久久亚洲AV成人无码国产|