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

            統計

            • 隨筆 - 50
            • 文章 - 42
            • 評論 - 147
            • 引用 - 0

            留言簿(6)

            隨筆分類

            文章分類

            Link

            搜索

            •  

            積分與排名

            • 積分 - 164705
            • 排名 - 159

            最新評論

            閱讀排行榜

            評論排行榜

            再談拷貝構造函數(Copy Constructor Function)

            前段時間有人發表了關于拷貝構造函數的問題,我覺得對于拷貝構造函數要掌握四點(以下以CCF代稱拷貝構造函數)
            第一:默認CCF提供對象之間的位拷貝(Bitwise Copy),對于指針類成員只會將至指針值復制
            第二:CCF在對象初始化時才發揮作用,而在對象賦值的時候不起作用
            第三:在沒有顯示聲明成員CCF的情況下,編譯器會自動生成默認CCF,如果顯示聲明了顯示CCF,則編譯器不會生成默認CCF,至少是不會調用
            第四:與構造函數不同,CCF并不會遞歸的調用基類的CCF,子類與基類的CCF是覆蓋關系,與就是說子類會尋找與自己關系最近的CCF調用,如果子類有CCF則僅調用子類CCF,如果子類沒有向上尋找,調用第一個找到的CCF
            第五:CCF的聲明及定義如下:

             1classname(classname const&obj)
             2{
             3   m1=obj.m1;
             4   m2=obj.m2;
             5   .
             6   Lp1=new type[size];
             7   memcpy_s(Lp1,size,obj.Lp1);
             8   Lp2=new type[size];
             9   memcpy_s(Lp2,size,obj.Lp2);
            10   .
            11}

            而具體到第二點,CCF在以下情況下也會被調用:
              1) 一個對象以值傳遞的方式傳入函數體;
              2) 一個對象以值傳遞的方式從函數返回;
              3) 一個對象需要通過另外一個對象進行初始化;
            除此之外,對于對象復制是我們經常會忽略或混淆的一點,在對賦值的時候不會調用CCF,需要自己去重載“=”

            注意:對于包含動態分配成員的類提供拷貝構造函數和重載"="賦值操作符號是一個良好的編程習慣。
            愿意如下:
            動態成員如指針,在默認CCF和默認“=”操作符下僅僅執行位拷貝,而指針所指向的內存區域不會被拷貝,造成內存錯誤操作
            以下例程可用來實驗:

            #pragma once
            #include 
            "tchar.h"

            class mycls
            {
            public:
                mycls(){};
                mycls(mycls const & obj)
             
            {
                    
            //delete[] mp_str1;
                    mp_str1=new TCHAR[100];
                    _tcscpy_s(mp_str1,
            100,obj.mp_str1);
                }

                
            char a[100000];
                TCHAR b[
            1000];
                
            //~mycls(void);
                int m_q;
                TCHAR
            * mp_str1;
                
            char* mp_str2;
            }
            ;
            class mycls2:public mycls
            {
            public:
                mycls2():bb(
            10){};
                   mycls2(mycls2 
            const&obj)
                
            {
                    bb
            =obj.bb;
                   }

                   
            int bb;
            }
            ;


             

            posted on 2008-12-05 23:19 pear_li 閱讀(3925) 評論(12)  編輯 收藏 引用 所屬分類: C++

            評論

            # re: 再談拷貝構造函數(Copy Constructor Function) 2008-12-07 14:02 sheep

            const& 是不是應該放在classname的前面啊~
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2008-12-08 00:59 pear_li

            @sheep
            ??去補充一下基本知識吧,最多也只是將const提前,不過沒有實質差別
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function)[未登錄] 2008-12-08 09:43 raof01

            第一,是bitwise initialization,member-wise copy。——這話是Inside C++ Object Model里說的,我也認同這種觀點。
            第四,不會遞歸調用基類CCF,但會遞歸調用個成員的CCF。——越俎代庖,做個補充:)
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2008-12-08 17:00 sheep

            恕我無知。
            我還是認為拷貝構造函數的參數const放后有些問題。
            如果放后面;如果這樣調用
            classname const a;
            classname b(a);
            在vc6.0和vs2005中編譯時會出錯,其他編譯器沒有試驗
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2008-12-09 02:31 pear_li

            @raof01
            呵呵,多謝補充
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2008-12-09 02:50 pear_li

            @sheep
            你說的問題我沒有遇到過,可以把出錯信息貼出來嗎?
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2008-12-09 10:32 sheep

            vc6.0
            Person(Person& const s) //出現警告
            warning C4227: anachronism used : qualifiers on reference are ignored
            Person p2(p1); //出現錯誤
            error C2558: class 'Person' : no copy constructor available

            vs2005
            錯誤 4 error C2558: class“Person”: 沒有可用的復制構造函數或復制構造函數聲明為“explicit”

            將const提到Person&的前面就不會又警告和錯誤,不知道怎么回事。
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2008-12-09 13:54 pear_li

            @sheep
            寫成
            Person(Person const& s)
            就沒問題了,關鍵在于const和&的順序,與class無關
            你那樣寫就相當于是引用常量,而引用無所謂常量變量,對于引用只有常量引用之說
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2008-12-10 00:37 sheep

            多謝指點了~
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2008-12-10 20:59 pear_li

            @sheep
            呵呵,客氣^_^
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2009-02-11 22:10 wingbake

            寫的很好,很受啟發!
            Mark!
              回復  更多評論    

            # re: 再談拷貝構造函數(Copy Constructor Function) 2009-05-22 16:28 thanks

            thanks very much
              回復  更多評論    
            久久精品中文字幕无码绿巨人| 人妻精品久久无码区| 久久AⅤ人妻少妇嫩草影院| 久久人人爽人人澡人人高潮AV| 久久精品视频一| 精品久久久久久| 久久强奷乱码老熟女网站| 久久久久久久99精品免费观看| 亚洲国产成人乱码精品女人久久久不卡 | 国产精品久久久久国产A级| 激情综合色综合久久综合| 亚洲国产精品18久久久久久| 91麻豆精品国产91久久久久久| 伊人久久大香线蕉av不变影院| 久久精品国产99国产精品| 久久99精品久久久久久| 午夜精品久久久久久中宇| 亚洲伊人久久成综合人影院 | 久久久久国产精品三级网| 无码人妻久久一区二区三区免费丨 | 日本亚洲色大成网站WWW久久| 久久本道伊人久久| 久久精品亚洲一区二区三区浴池 | 中文字幕亚洲综合久久菠萝蜜| 国产精品岛国久久久久| 久久亚洲AV成人无码电影| AV无码久久久久不卡蜜桃| 四虎久久影院| 青青久久精品国产免费看| 久久国产综合精品五月天| 日本道色综合久久影院| 日本免费一区二区久久人人澡| 97久久精品国产精品青草| 久久精品人人槡人妻人人玩AV| 国产欧美久久久精品影院| 无夜精品久久久久久| 久久久午夜精品福利内容| 亚洲欧美久久久久9999| 久久久久久精品免费看SSS| 色欲综合久久中文字幕网| 久久精品亚洲日本波多野结衣|