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

            寶杉的博客

            UNIX/LINUX;ACE;SNMP;C++
            posts - 33, comments - 23, trackbacks - 0, articles - 0

            08-13復習

            Posted on 2007-08-30 10:28 寶杉 閱讀(199) 評論(0)  編輯 收藏 引用 所屬分類: C++

             

            析構函數

            構造函數初始化表:構造函數特殊的初始化方式“初始化表達式表”(簡稱初始化表)。

            初始化表位于函數參數表之后,卻在函數體 {} 之前。這說明該表里的初始化工作發生在函數體內的任何代碼被執行之前。

            規則

            u       如果類存在繼承關系,派生類必須在其初始化表里調用基類的構造函數。

            u       類的const常量只能在初始化表里被初始化,因為它不能在函數體內用賦值的方式來初始化。

            u       類的數據成員的初始化可以采用初始化表或函數體內賦值兩種方式,這兩種方式的效率不完全相同。

            效率

            1 內部成員:

            初始化表和函數體內賦值都可以,但效率不完全相同,但后者更為清晰直觀。

            例子:

            class F

            {

             public:

                F(int x, int y);        // 構造函數

             private:

                int m_x, m_y;

                int m_i, m_j;

            }

            F::F(int x, int y)

             : m_x(x), m_y(y)          

            {

               m_i = 0;

               m_j = 0;

            }

            F::F(int x, int y)

            {

               m_x = x;

               m_y = y;

               m_i = 0;

               m_j = 0;

            }

            示例9-2(c) 數據成員在初始化表中被初始化     示例9-2(d) 數據成員在函數體內被初始化

            兩種方式效率區別不大。

             

            2 非內部成員:

            只能用初始化表,提高效率。

            例子:

                class A

            {…

                A(void);                // 無參數構造函數

                A(const A &other);      // 拷貝構造函數

                A & operate =( const A &other); // 賦值函數

            };

             

                class B

                {

                 public:

                    B(const A &a); // B的構造函數

                 private: 

                    A m_a;         // 成員對象

            };

            比較與分析:

            B::B(const A &a)

             : m_a(a)          

            {

               …

            }

            B::B(const A &a)

            {

            m_a = a;

            }

            1 B類構造函數的初始化里,調用了A類的拷貝構造函數。

            2 B類構造初始化里,隱藏了以下幾個步驟:

            先創建了a對象,調用了A類的無參數構造函數;

            把a賦值給m_a,調用了A類的賦值函數;

             

            深入探討:

            構造和析構的次序?

            構造從最深處的基類開始的,先一層層調用基類的構造函數,然后調用成員對象的構造函數。

            而析構函數嚴格按照構造函數相反的次序執行,該次序唯一,以便讓編譯器自動執行析構函數。

            特別之處是,成員對象初始化次序不受構造函數初始化表次序影響,由在類中聲明的次序決定。而類聲明是唯一的,構造函數卻可能有多個,所以有多個不同次序函數初始化表。如果按照構造函數的次序構造,那么解析函數不能得到唯一的逆序。

            99久久99久久精品免费看蜜桃| 国产三级精品久久| 久久人人爽人人爽人人爽| 人妻少妇久久中文字幕| 精品熟女少妇av免费久久| 久久精品一区二区国产| 少妇久久久久久被弄到高潮| 色偷偷88888欧美精品久久久| 精品999久久久久久中文字幕| 久久亚洲中文字幕精品一区| 久久影院综合精品| 少妇被又大又粗又爽毛片久久黑人 | 久久久久香蕉视频| 囯产精品久久久久久久久蜜桃| .精品久久久麻豆国产精品| 青青久久精品国产免费看| 久久天天躁狠狠躁夜夜网站| 久久久久99精品成人片| 久久精品水蜜桃av综合天堂| 日韩久久久久中文字幕人妻| 国产一级持黄大片99久久| av色综合久久天堂av色综合在| 一本色道久久88加勒比—综合| 国内精品伊人久久久久777| 久久国产精品免费一区| 91久久精一区二区三区大全| 国产成年无码久久久免费| 久久精品人妻一区二区三区| 久久精品国产亚洲一区二区| 国产aⅴ激情无码久久| 亚洲va久久久久| 久久只有这精品99| 欧美精品福利视频一区二区三区久久久精品 | 久久夜色精品国产欧美乱| 精品国产乱码久久久久软件| 久久久久亚洲精品天堂久久久久久| 久久综合欧美成人| 国产午夜免费高清久久影院| 97久久久久人妻精品专区| 久久丫精品国产亚洲av| 2020久久精品国产免费|