• <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 寶杉 閱讀(197) 評論(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综合影院 | 久久国语露脸国产精品电影| 久久综合亚洲色一区二区三区| 一本色道久久HEZYO无码| 国内精品久久久久伊人av| 久久久久久A亚洲欧洲AV冫 | 国产一区二区三区久久| 亚洲国产精品无码久久青草 | 亚洲精品无码久久一线| 久久播电影网| 国产精品福利一区二区久久| 久久精品aⅴ无码中文字字幕不卡| 九九精品99久久久香蕉| 思思久久99热只有频精品66| 青青热久久综合网伊人| 久久亚洲私人国产精品vA | 久久精品嫩草影院| 97精品伊人久久大香线蕉| 国产午夜福利精品久久| 狠狠色丁香久久综合五月| 伊人久久大香线蕉综合热线| 欧美亚洲国产精品久久蜜芽| 久久久久亚洲AV无码专区体验| 亚洲国产欧美国产综合久久| 欧美大战日韩91综合一区婷婷久久青草| 狠狠综合久久综合中文88 | 久久香蕉国产线看观看乱码| 亚洲国产另类久久久精品小说 | 久久久黄片| 狠狠人妻久久久久久综合| 88久久精品无码一区二区毛片 | 亚洲欧洲精品成人久久曰影片| 久久国产免费直播| 国产免费久久精品丫丫| 国产精品成人99久久久久 | 久久久艹| 久久国产成人| 亚洲人成无码www久久久| 日韩十八禁一区二区久久| 伊人精品久久久久7777| 久久只有这里有精品4|