• <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 寶杉 閱讀(198) 評論(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類的賦值函數;

             

            深入探討:

            構造和析構的次序?

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

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

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

            青青青伊人色综合久久| 久久精品一区二区三区AV| 国产欧美久久一区二区| 欧美久久亚洲精品| 久久99精品久久久久久动态图| 久久精品国产精品亚洲精品| 国产成人久久精品二区三区| 午夜不卡久久精品无码免费| 亚洲国产成人久久精品99| 日韩欧美亚洲综合久久影院d3| 国产精品成人久久久久久久| 久久综合亚洲色一区二区三区| 久久久噜噜噜久久| 国产三级精品久久| 综合网日日天干夜夜久久 | 日本三级久久网| 久久婷婷五月综合国产尤物app| 精品乱码久久久久久久| 亚洲精品第一综合99久久| 精品国产乱码久久久久久人妻| 99久久久久| 欧美精品一区二区精品久久| 国产日韩久久久精品影院首页 | 国产香蕉久久精品综合网| 国产精品岛国久久久久| 亚洲中文字幕久久精品无码APP| 成人亚洲欧美久久久久| 97久久精品国产精品青草| 伊人久久大香线蕉综合网站| 久久久久99精品成人片| 色欲综合久久躁天天躁| 久久成人18免费网站| 亚洲精品无码专区久久同性男| 欧美精品一本久久男人的天堂| 国产精品禁18久久久夂久| 久久久久久国产精品免费无码 | 国产精品久久久久久一区二区三区| 国产精品久久新婚兰兰| 久久久久亚洲AV无码专区首JN | 色综合久久中文综合网| 99久久国产综合精品五月天喷水 |