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

            zhgw01

            Handle Class 和 Interface Class

            這兩者都是為了降低文件間的編譯依存

            1.編譯依存
            #include"file1.h"
            #include
            "file2.h"

            class class_name
            {
             member1 m_m1;
             member2 m_m2;
            public:
             member1 get_member_1()
            const{};
             member2 get_member_2()
            const{};
            }
            ;
            假設(shè)上面的頭文件為file.h,當(dāng)file1.h或者file2.h發(fā)生變化,或者file中的class_name的實現(xiàn)發(fā)生變化時,所有包含file.h的文件都得重新編譯,當(dāng)file.h被很多文件包含時,即使只是對class_name做了小小的改動,也要花費大量的編譯時間。

            2. Handle class (句柄類)
            handle classs 只是提高了所有的接口,同時包含了一個指向真正實現(xiàn)類的指針。真正的實現(xiàn)類包含在另外一個文件中,當(dāng)要修改這個類時,只有file.h會引起重編譯,而包含file.h的其它文件不會引起重編譯
            #include"file1.h" //contain member1
            #include
            "file2.h" //contain member2
               #include"implement.h"

            class class_name
            {
              class_impl
            * implement; //一般會用shared pointer

            public:
             member1 get_member_1()
            const
             
            {
               
            return implement->get_member_1();
             }


             member2 get_member_2() 
            const
             
            {
               
            return implement->get_member_2();
             }

            }
            ;

            下面的是implement.h的實現(xiàn)

            class class_impl
            {
              member1 m_1;
              member2 m_2;
            public;
              member1 get_member_1()
            const {}
              member2 get_member_2()
            const {}
            }
            ;

            2.Interface class
            這是制作handle class的另外一種方法
            首先聲明的class是抽象類,一般里面的接口都是純虛函數(shù),就像Java的Interface
            然后提高一個static的create函數(shù)(就是工廠方法),這個函數(shù)返回改抽象類的某個具體子類的對象,函數(shù)聲明中的返回值仍然是該抽象類的指針或引用。

            具體子類在另外一個文件中聲明。

            posted on 2008-10-20 15:02 apacs 閱讀(1818) 評論(0)  編輯 收藏 引用 所屬分類: c++

            My Links

            Blog Stats

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            很黄很污的网站久久mimi色| 人妻无码精品久久亚瑟影视| 久久久久亚洲精品男人的天堂| 性高湖久久久久久久久| 久久99精品九九九久久婷婷| 久久99国产精品一区二区| 中文字幕乱码人妻无码久久| 要久久爱在线免费观看| 久久成人国产精品一区二区| 久久精品这里热有精品| 久久国产精品一区二区| 久久96国产精品久久久| 99久久精品日本一区二区免费| 久久精品99久久香蕉国产色戒| 久久久久波多野结衣高潮| 囯产精品久久久久久久久蜜桃 | 欧美激情精品久久久久| 亚洲国产精品久久久久婷婷老年| 久久国产精品-国产精品| 青青青国产精品国产精品久久久久 | 亚洲AV日韩精品久久久久| 久久亚洲日韩看片无码| 久久精品夜夜夜夜夜久久| 久久青青草原国产精品免费 | 亚洲精品无码久久久久久| 熟妇人妻久久中文字幕| 久久99免费视频| 久久黄色视频| 精品国产乱码久久久久久呢| 国产亚洲综合久久系列| 国产亚洲精久久久久久无码AV| 亚洲色欲久久久久综合网 | 中文字幕无码久久久| 久久综合亚洲欧美成人| 狠狠色伊人久久精品综合网 | 四虎国产精品成人免费久久| 日韩AV无码久久一区二区 | 伊人久久大香线蕉亚洲五月天| 色偷偷888欧美精品久久久| 国产69精品久久久久APP下载 | 久久99精品国产麻豆宅宅|