• <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年2月>
            272829303112
            3456789
            10111213141516
            17181920212223
            2425262728291
            2345678

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

            常用鏈接

            留言簿(21)

            隨筆分類

            隨筆檔案

            SDL相關(guān)網(wǎng)站

            我的個人網(wǎng)頁

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 492144
            • 排名 - 38

            最新評論

            閱讀排行榜

            評論排行榜

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

            #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;
            }
            那么,結(jié)果運行就會出現(xiàn)貌似創(chuàng)建一次,但是卻銷毀了兩次的假象。這當(dāng)然是不可能發(fā)生的,但是郁悶的是,C++中的構(gòu)造和析構(gòu)不總是成對出現(xiàn)的,比如我們前面說到的手動顯式調(diào)用析構(gòu)函數(shù)的情況。所以,如果放在大的項目中,這為我們的調(diào)試帶來更多的困難。
                    所以,結(jié)論是,如果A類構(gòu)造具有堆操作,有可能把A類作為B類的成員數(shù)據(jù),B類又有可能通過成員初始化列表構(gòu)造A對象,請一定別忘記手寫復(fù)制構(gòu)造函數(shù)。
            亚洲国产成人精品女人久久久| 99久久成人18免费网站| 国产成人久久精品一区二区三区 | 久久伊人五月天论坛| 久久99热这里只频精品6| 久久久免费精品re6| 久久久久亚洲AV成人网人人软件| 一本大道久久东京热无码AV| 99久久精品国产麻豆| 亚洲国产成人久久一区WWW| 99久久精品日本一区二区免费| 99久久国产综合精品五月天喷水 | 久久无码国产专区精品| 久久99精品久久久久久hb无码| 久久久久99精品成人片三人毛片| 香蕉久久av一区二区三区| 久久精品国产亚洲AV不卡| 国产精品视频久久久| 中文无码久久精品| 人妻无码久久精品| 久久99精品久久久久久野外| 久久精品国产亚洲AV高清热| 久久精品亚洲AV久久久无码| 久久久久久国产精品美女| 日本免费一区二区久久人人澡| 亚洲成色www久久网站夜月| 精品人妻伦一二三区久久| 久久福利青草精品资源站免费| 亚洲午夜久久久久妓女影院| 久久婷婷五月综合国产尤物app | 91久久精品国产成人久久| 69久久夜色精品国产69| 久久精品国产亚洲AV无码娇色| 久久99九九国产免费看小说| 久久亚洲AV永久无码精品| 九九久久精品无码专区| 欧美亚洲日本久久精品| 思思久久好好热精品国产 | 久久成人精品视频| 久久精品国产久精国产| 亚洲国产精久久久久久久|