c++類建構函式初始化列表
建構函式初始化列表以乙個冒號開始,接著是以逗號分隔的資料成員列表,每個資料成員後面跟乙個放在括號中的初始化式。例如:
cexample
//建構函式內部賦值
cexample()
上面的例子中兩個建構函式的結果是一樣的。
上面的建構函式(使用初始化列表的建構函式)顯式的初始化類的成員;而沒使用初始化列表的建構函式是對類的成員賦值,並沒有進行顯式的初始化。
初始化和賦值對內建型別的成員沒有什麼大的區別,像上面的任乙個建構函式都可以。對非內建型別成員變數,為了避免兩次構造,推薦使用類建構函式初始化列表。
但有的時候必須用帶有初始化列表的建構函式:
1.成員型別是沒有預設建構函式的類。這種說話或者向成員的建構函式傳遞引數。若沒有提供顯示初始化式,則編譯器隱式使用成員型別的預設建構函式,若類沒有預設建構函式,則編譯器嘗試使用預設建構函式將會失敗。
2.const成員
或引用型別的成員。因為const物件或引用型別只能初始化,不能對他們賦值。
初始化資料成員與對資料成員賦值的含義是什麼?有什麼區別?
首先把資料成員按型別分類並分情況說明:
1.內建資料型別,復合型別(指標,引用)
在成員初始化列表和建構函式體內進行,在效能和結果上都是一樣的
2.使用者定義型別(類型別)
結果上相同,但是效能上存在很大的差別。因為類型別的資料成員物件在進入函式體前已經構造完成,也就是說在成員初始化列表處進行構造物件的工作,呼叫建構函式,在進入函式體之後,進行的是對已經構造好的類物件的賦值,又呼叫個拷貝賦值操作符才能完成(如果並未提供,則使用編譯器提供的預設按成員賦值行為)
note:
初始化列表的成員初始化順序:
c++初始化類成員時,是按照宣告的順序初始化的,而不是按照出現在初始化列表中的順序。
example:
cmyclass
;cmyclass::cmyclass(
intx,
inty) : m_y(y), m_x(m_y)
你可能以為上面的**將會首先做m_y=i,然後做m_x=m_y,最後它們有相同的值。但是編譯器先初始化m_x,然後是m_y,,因為它們是按這樣的順序宣告的。結果是m_x將有乙個不可**的值。有兩種方法避免它,乙個是總是按照你希望它們被初始化的順序宣告成員,第二個是,如果你決定使用初始化列表,總是按照它們宣告的順序羅列這些成員。這將有助於消除混淆。
子類向父類傳引數
#include
class animal
;void main()
注意程式中以粗體顯示的**。在fish類的建構函式後,加乙個冒號(:),然後加上父類的帶引數的建構函式。這樣,在子類的建構函式被呼叫時,系統就會去呼叫父類的帶引數的建構函式去構造物件。這種初始化方式,還常用來對類中的常量(const)成員進行初始化,如下面的**所示:
class point
;當然,類中普通的成員變數也可以採取此種方式進行初始化,然而,這就沒有必要了。
C 類建構函式初始化列表,子類向父類傳引數
c 類建構函式初始化列表 建構函式初始化列表以乙個冒號開始,接著是以逗號分隔的資料成員列表,每個資料成員後面跟乙個放在括號中的初始化式。例如 cexample 建構函式內部賦值 cexample 上面的例子中兩個建構函式的結果是一樣的。上面的建構函式 使用初始化列表的建構函式 顯式的初始化類的成員 ...
c 子類建構函式初始化及父類構造初始化
我們知道,構造方法是用來初始化類物件的。如果在類中沒有顯式地宣告建構函式,那麼編譯器會自動建立乙個預設的建構函式 並且這個預設的建構函式僅僅在沒有顯式地宣告建構函式的情況下才會被建立建立。1.父類沒有宣告建構函式 1 子類也沒有宣告自己的建構函式,則父類和子類均由編譯器生成預設的建構函式。2 子類中...
關於初始化列表,父類建構函式以及子類建構函式
在stackoverflower上發現的乙個問題,覺得挺有意思,自己之前也沒有注意到,貼出來分享一下 這裡面的內容實在討論在子類的初始化列表中,如果對子類的成員變數進行初始化,然後呼叫父類的建構函式,那麼他們的執行順序會是什麼樣的,話不多說,碼來!includeusing namespace std...