• <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
            對于成員初始化列表,熟悉有不是很熟悉。什么情況下使用呢?心里還是發怵,說不出所以然來。

            學習是王道,搜索是方法。有了網絡就是好。

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

            成員初始化列表

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

                    計算階段由構造函數體內的所有語句構成。在計算階段中,數據成員的設置被認為是賦值,而不是初始化。

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

            1.必須這樣做:

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

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

            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)當類成員中含有一個const成員時

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

            #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.效率要求這樣做:

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

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

            現在明白為什么要使用成員初始化列表了。

            這里再強調一下類的初始化的順序,應該是類成員變量的初始化不是按照初始化表的順序被初始化的,而是按照在類中聲明的順序被初始化的。
            這是摘自:Effective C++學習筆記:初始化列表中成員列出的順序和它們在類中聲明的順序相同 http://m.shnenglu.com/xczhang/archive/2008/01/22/41613.html

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

            注意:上述內容不適用于static變量,static變量應該在類的構造函數前被初始化。



            好文章拿來學習,請作者見諒哈!

            posted on 2009-06-18 13:33 Sandy 閱讀(472) 評論(0)  編輯 收藏 引用 所屬分類: c++學習
            999久久久国产精品| 久久99国产一区二区三区| 亚洲国产视频久久| 91久久精一区二区三区大全| 亚洲欧美精品伊人久久| 97香蕉久久夜色精品国产| 国产精品对白刺激久久久| 久久精品国产亚洲精品| 欧美一区二区三区久久综| 久久精品不卡| 国产亚洲精品美女久久久| 午夜肉伦伦影院久久精品免费看国产一区二区三区| 欧美久久综合九色综合| 国产精品青草久久久久婷婷| 一本久久综合亚洲鲁鲁五月天| 久久国产精品一国产精品金尊| 久久久久久久综合狠狠综合| 国产精品成人无码久久久久久| 蜜臀久久99精品久久久久久小说| 亚洲国产高清精品线久久| 成人精品一区二区久久久| 97久久超碰国产精品旧版| 99精品久久久久久久婷婷| 无码任你躁久久久久久久| 久久精品成人一区二区三区| 国产精品一区二区久久精品无码 | 狠狠综合久久AV一区二区三区 | 亚洲中文字幕无码久久2020| 亚洲午夜精品久久久久久app| 亚洲国产精品婷婷久久| 久久香蕉一级毛片| 久久国产一区二区| 欧美久久综合性欧美| 久久国产精品-久久精品| 久久A级毛片免费观看| 久久天堂AV综合合色蜜桃网| 久久久久免费看成人影片| 久久久久亚洲AV片无码下载蜜桃| 狠狠综合久久AV一区二区三区| 少妇无套内谢久久久久| 久久久久久午夜成人影院|