以下三種情況下需要使用初始化成員列表:
一,需要初始化的資料成員是物件的情況;
二,需要初始化const修飾的類成員;
三,需要初始化引用成員資料;
原因:
c++可以定義引用型別的成員變數,引用型別的成員變數必須在建構函式的初始化列表中進行初始化。對於類成員是const修飾,或是引用型別的情況,是不允許賦值操作的,(顯然嘛,const就是防止被錯誤賦值的,引用型別必須定義賦值在一起),因此只能用初始化列表對齊進行初始化。成員型別是沒有預設建構函式的類。若沒有提供顯示初始化式,則編譯器隱式使用成員型別的預設建構函式,若類沒有預設建構函式,則編譯器嘗試使用預設建構函式將會失敗。(也就是這三種情況必須使用初始化列表)
我們定義乙個如下的person類:
class person //default constructor function
person(string name, string phone, string addr)
m_name = name; //想採用賦值初始化資料成員
m_phone = phone;
m_addr = addr;
private:
const string m_name;
const string m_phone;
const string m_addr;
編譯後發現這個類的第二個帶引數的建構函式是錯誤的。我們建立乙個person物件:
person p("marcky", "13233232", "cqupt"); //呼叫帶引數的建構函式建立乙個person物件 建立物件的過程分為了兩步:
一、從記憶體中分配實際的空間給物件p,其三個字串物件的資料成員是呼叫的預設建構函式初始化為空。也就說,此時為止,物件p的三個資料成員都是乙個空的字串。
二、執行呼叫的建構函式的函式體語句,完成對資料成員的賦值,以此達到我們期望的建立乙個指定person物件,而不是空物件。
從上面的第二步就可以看到,我們在對三個const物件進行賦值操作,這顯然是不允許的操作,因此利用這個建構函式建立person將以失敗告終。要想成功的建立乙個特定的person物件,我們需要建構函式初始化列表:
person(string name, string phone, string addr)
:m_name(name), m_phone(phone), m_addr(addr) //冒號開始定義初始化列表 使用初始化列表建立物件的建構函式同樣是通過上述的兩個步驟來完成的,不同之處在於建立物件的資料成員時使用的不是預設建構函式,而是根據指定引數呼叫了相應的建構函式,以此建立特定的物件,而不是空物件。這樣一來,物件的資料成員的特定值在建立物件的時候就被賦予了相應的成員,而不是在建立物件完成之後再通過賦值語句去修改資料成員,因此利用建構函式初始化列表就可以成功的建立具有const資料成員的對物件了。
沒有預設建構函式的類型別成員,如果不在初始化列表中初始化的話,那麼建立該物件的時候,由於沒有指定相應的「實參」,編譯器就會去呼叫預設建構函式來建立物件,必然會以失敗而告終。
注1:資料成員被初始化的順序與建構函式初始化列表中的次序無關,而是與成員的定義順序一致。
注2:使用初始化列表效率更高,如果在建構函式中賦值則是拷貝,如果是初始化列表中則是初始化,賦值和初始化當然效率不一樣了。
C 初始化函式列表
在以下三種情況下需要使用初始化成員列表 一,需要初始化的資料成員是物件的情況 二,需要初始化const修飾的類成員 三,需要初始化引用成員資料 原因 c 可以定義引用型別的成員變數,引用型別的成員變數必須在建構函式的初始化列表中進行初始化。對於類成員是const修飾,或是引用型別的情況,是不允許賦值...
C 初始化函式列表
c 初始化函式列表 在以下三種情況下需要使用初始化成員列表 一,需要初始化的資料成員是物件的情況 二,需要初始化const修飾的類成員 三,需要初始化引用成員資料 原因 c 可以定義引用型別的成員變數,引用型別的成員變數必須在建構函式的初始化列表中進行初始化。對於類成員是const修飾,或是引用型別...
C 初始化函式列表詳細解析
c 可以定義引用型別的成員變數,引用型別的成員變數必須在建構函式的初始化列表中進行初始化 在以下三種情況下需要使用初始化成員列表 一,需要初始化的資料成員是物件的情況 二,需要初始化const修飾的類成員 三,需要初始化引用成員資料 原因 c 可以定義引用型別的成員變數,引用型別的成員變數必須在建構...