• <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>
            隨筆 - 96  文章 - 255  trackbacks - 0
            <2008年3月>
            2425262728291
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            E-mail:zbln426@163.com QQ:85132383 長期尋找對戰略游戲感興趣的合作伙伴。

            常用鏈接

            留言簿(21)

            隨筆分類

            隨筆檔案

            SDL相關網站

            我的個人網頁

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 494279
            • 排名 - 39

            最新評論

            閱讀排行榜

            評論排行榜

                    C++為我們提供了默認的復制構造函數,賦值函數和析構函數,使用的全部是“淺復制”,即僅僅復制棧上的數據。換句話說,如果我們涉及到了對堆數據的操作,這些函數都必須我們自己重新來寫。我很郁悶為什么在編譯的時候,C++不能自己發現構造函數使用了堆操作,從而提醒不要使用默認的這三個函數。也許是因為要編譯器做到智能的判斷很難吧。用new...delete或許很容易看出來,但是更多的函數調用,特別是涉及到C風格的函數的時候,真的很難判斷哪些函數使用到了堆操作。
                    而這三個函數的作用可以說是巨大的!析構就不說了,析構可以說是C++永遠的痛。復制構造函數用得最多的地方,恐怕就是成員初始化列表的時候,這幾乎是在一個類成員數據使用到另外一個類對象時候的唯一方法。而賦值函數則是把數據從語句體(“{}”對,循環,判斷)中帶出的最簡單方法——雖然我們現在可以很方便的使用vector。
                    這里先說說復制構造函數吧。如果遺漏申明,又不慎用到,比如這個例子:

            #include <iostream>
            #include 
            <vector>

            class A
            {
            private:
                
            int a;
            public:
                A(
            int _a): a(_a)
                {
                    std::cout 
            << "A created!\n";
                }
            /*
                A(const A& copy): a(copy.a)
                {
                    std::cout << "A copy created!\n";
                }
            */
                
            ~A()
                {
                    std::cout 
            << "A destroyed!\n";
                }
                
            void show() const
                {
                    std::cout 
            << a << std::endl;
                }
            };

            int main(int argc, char* argv[])
            {
                A a(
            1);
                A b(a);

                
            return 0;
            }
            那么,結果運行就會出現貌似創建一次,但是卻銷毀了兩次的假象。這當然是不可能發生的,但是郁悶的是,C++中的構造和析構不總是成對出現的,比如我們前面說到的手動顯式調用析構函數的情況。所以,如果放在大的項目中,這為我們的調試帶來更多的困難。
                    所以,結論是,如果A類構造具有堆操作,有可能把A類作為B類的成員數據,B類又有可能通過成員初始化列表構造A對象,請一定別忘記手寫復制構造函數。
            posted on 2008-04-14 11:50 lf426 閱讀(547) 評論(0)  編輯 收藏 引用 所屬分類: 語言基礎、數據結構與算法
            久久这里只有精品首页| 久久精品国产99国产精品| 午夜精品久久久久久中宇| 免费国产99久久久香蕉| 亚洲国产成人精品女人久久久| 亚洲&#228;v永久无码精品天堂久久 | 亚洲精品国产字幕久久不卡| 国产精品久久自在自线观看| 色诱久久av| 国内精品伊人久久久久网站| 一本久久a久久精品亚洲| 精品久久人人爽天天玩人人妻| 久久精品水蜜桃av综合天堂| 欧美精品一区二区久久| 欧美久久综合性欧美| 国产精品久久久久久吹潮| 久久综合亚洲色HEZYO社区| 精品无码久久久久久久动漫| 久久综合狠狠综合久久| 国产欧美久久久精品影院| 国内精品久久久久久久久电影网| 久久久久亚洲AV成人片| 午夜欧美精品久久久久久久| 97精品伊人久久久大香线蕉| 亚洲v国产v天堂a无码久久| 久久久久国产一级毛片高清板| 亚洲午夜精品久久久久久人妖| 999久久久无码国产精品| 久久婷婷五月综合色高清| 久久SE精品一区二区| 久久精品国产亚洲AV香蕉| 久久精品国产2020| 午夜天堂精品久久久久| 久久精品国产亚洲77777| 成人妇女免费播放久久久| 99精品久久精品| 97久久精品人人澡人人爽| 国内精品久久久久久久影视麻豆| 狠狠人妻久久久久久综合蜜桃| AAA级久久久精品无码区| 久久精品中文字幕第23页|