• <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>
            春暖花開
            雪化了,花開了,春天來了
            posts - 149,comments - 125,trackbacks - 0
            對于成員初始化列表,熟悉有不是很熟悉。什么情況下使用呢?心里還是發(fā)怵,說不出所以然來。

            學(xué)習(xí)是王道,搜索是方法。有了網(wǎng)絡(luò)就是好。

            摘自:http://www.cnblogs.com/heyutao/archive/2009/05/22/1487081.html

            成員初始化列表

            類對象的構(gòu)造順序是這樣的:
            1.分配內(nèi)存,調(diào)用構(gòu)造函數(shù)時,隱式/顯示的初始化各數(shù)據(jù)成員
                    初始化階段可以是顯式的或隱式的,取決于是否存在成員初始化表。隱式初始化階段按照聲明的順序依次調(diào)用所有基類的缺省構(gòu)造函數(shù),然后是所有成員類對象的缺省構(gòu)造函數(shù)。
            2.進(jìn)入構(gòu)造函數(shù)后在構(gòu)造函數(shù)中執(zhí)行一般計算

                    計算階段由構(gòu)造函數(shù)體內(nèi)的所有語句構(gòu)成。在計算階段中,數(shù)據(jù)成員的設(shè)置被認(rèn)為是賦值,而不是初始化。

            使用初始化列表有兩個原因:

            1.必須這樣做:

                    三種情況下需要使用初始化成員列表
                    1)對象成員;
                    2)const修飾的成員;
                    3)引用成員數(shù)據(jù);

            (1)如果有一個類成員,它本身是一個類或者是一個結(jié)構(gòu),而且這個成員它只有一個帶參數(shù)的構(gòu)造函數(shù),而沒有默認(rèn)構(gòu)造函數(shù),這時要對這個類成員進(jìn)行初始化,就必須調(diào)用這個類成員的帶參數(shù)的構(gòu)造函數(shù),如果沒有初始化列表,那么他將無法完成第一步,就會報錯。

            using namespace std;
            class ABC
            {
            public:
                ABC(
            int x,int y,int z):a(x),b(y),c(z){};
            private:
              
            int a;
                
            int b;
                
            int c;
            }
            ;
            class MyClass
            {
            public:
                MyClass(
            int a,int b,int c):abc(a,b,c){}
            private:
                ABC abc;
            }
            ;

            int main()
            {
                MyClass o(
            1,2,3);
                
            return 0;
            }

            (2)當(dāng)類成員中含有一個const成員時

            (3)當(dāng)類成員中含有一個引用時

            #include<iostream>
            using namespace std;

            class ConstRef {
            public:
                ConstRef(
            int i);
                
            void print();
            private:
                
            int a;
                
            const int b;//const成員
                int &c;//引用
            }
            ;

            ConstRef::ConstRef(
            int i):b(i),c(a)//含有一個const對象時,或者是一個引用時使用初始化成員列表
            {
                a 
            = i;       // ok
                
            //b = i;         // 錯誤
                
            //c = a;       // 錯誤
            }

            void ConstRef::print()
            {
                cout
            <<a<<endl;
                cout
            <<b<<endl;
                cout
            <<c<<endl;
            }

            int main()
            {
                ConstRef o(
            1);
                o.print();
                
            return 0;
            }


             

            2.效率要求這樣做:

            類對象的構(gòu)造順序顯示,進(jìn)入構(gòu)造函數(shù)體后,進(jìn)行的是計算,是對他們的賦值操作,顯然,賦值和初始化是不同的,這樣就體現(xiàn)出了效率差異,如果不用成員初始化列表,那么類對自己的類成員分別進(jìn)行的是一次隱式的默認(rèn)構(gòu)造函數(shù)的調(diào)用,和一次復(fù)制操作符的調(diào)用,如果是類對象,這樣做效率就得不到保障。

            注意:構(gòu)造函數(shù)需要初始化的數(shù)據(jù)成員,不論是否顯式的出現(xiàn)在構(gòu)造函數(shù)的成員初始化列表中,都會在該處完成初始化,并且初始化的順序和其在聲明時的順序是一致的,與列表的先后順序無關(guān),所以要特別注意,保證兩者順序一致才能真正保證其效率。

            現(xiàn)在明白為什么要使用成員初始化列表了。

            這里再強(qiáng)調(diào)一下類的初始化的順序,應(yīng)該是類成員變量的初始化不是按照初始化表的順序被初始化的,而是按照在類中聲明的順序被初始化的。
            這是摘自:Effective C++學(xué)習(xí)筆記:初始化列表中成員列出的順序和它們在類中聲明的順序相同 http://www.shnenglu.com/xczhang/archive/2008/01/22/41613.html

            為什么會這樣呢?我們知道,對一個對象的所有成員來說,它們的析構(gòu)函數(shù)被調(diào)用的順序總是和它們在構(gòu)造函數(shù)里被創(chuàng)建的順序相反。那么,如果允許上面的情況(即,成員按它們在初始化列表上出現(xiàn)的順序被初始化)發(fā)生,編譯器就要為每一個對象跟蹤其成員初始化的順序,以保證它們的析構(gòu)函數(shù)以正確的順序被調(diào)用。這會帶來昂貴的開銷。所以,為了避免這一開銷,同一種類型的所有對象在創(chuàng)建(構(gòu)造)和摧毀(析構(gòu))過程中對成員的處理順序都是相同的,而不管成員在初始化列表中的順序如何。

            注意:上述內(nèi)容不適用于static變量,static變量應(yīng)該在類的構(gòu)造函數(shù)前被初始化。



            好文章拿來學(xué)習(xí),請作者見諒哈!

            posted on 2009-06-18 13:33 Sandy 閱讀(466) 評論(0)  編輯 收藏 引用 所屬分類: c++學(xué)習(xí)
            亚洲精品乱码久久久久久蜜桃图片 | 久久无码中文字幕东京热| 精品综合久久久久久88小说| 精品久久人人做人人爽综合| 亚洲一级Av无码毛片久久精品| 久久久久无码精品国产| 国产精品日韩欧美久久综合| 天天影视色香欲综合久久| 久久亚洲AV成人出白浆无码国产| 久久综合丁香激情久久| 中文字幕精品久久| 久久91综合国产91久久精品| 色婷婷久久久SWAG精品| 久久婷婷五月综合97色| 国产高潮国产高潮久久久91 | 久久精品国产亚洲AV久| 久久亚洲国产午夜精品理论片| 欧美一区二区久久精品| 久久精品国产福利国产秒| 777午夜精品久久av蜜臀| 久久综合综合久久狠狠狠97色88| 久久精品国产久精国产一老狼| 精品久久人人妻人人做精品| 久久久久亚洲精品天堂| 精品久久久一二三区| 久久精品国产一区二区三区| 97久久精品国产精品青草| 久久精品国产99国产精品导航| 免费一级欧美大片久久网| 国产精品久久久久久福利69堂| 亚洲成色WWW久久网站| 久久久久国产精品三级网| 亚洲一本综合久久| 91精品国产综合久久香蕉| 九九99精品久久久久久| 国内精品伊人久久久久AV影院| 久久久精品人妻一区二区三区蜜桃 | 久久九九久精品国产免费直播| 日本免费一区二区久久人人澡| 久久精品国产亚洲麻豆| 久久99精品国产一区二区三区 |