有些成員變量的數據類型比較特別,它們的初始化方式也和普通數據類型的成員變量有所不同。這些特殊的類型的成員變量包括:
a.引用
b.常量
c.靜態
d.靜態常量(整型)
e.靜態常量(非整型)
常量和引用,必須通過參數列表進行初始化。
靜態成員變量的初始化也頗有點特別,是在類外初始化且不能再帶有static關鍵字,其本質見文末。
參考下面的代碼以及其中注釋:
#include靜態成員屬於類作用域,但不屬於類對象,和普通的static變量一樣,程序一運行就分配內存並初始化,生命周期和程序一致。using namespace std; class BClass { public: BClass() : i(1), ci(2), ri(i){} // 對於常量型成員變量和引用型成員變量,必須通過參數化列表的方式進行初始化 //普通成員變量也可以放在函數體裡,但是本質其實已不是初始化,而是一種普通的運算操作-->賦值運算,效率也低 private: int i; // 普通成員變量 const int ci; // 常量成員變量 int &ri; // 引用成員變量 static int si; // 靜態成員變量 //static int si2 = 100; // error: 只有靜態常量成員變量,才可以這樣初始化 static const int csi; // 靜態常量成員變量 static const int csi2 = 100; // 靜態常量成員變量的初始化(Integral type) (1) static const double csd; // 靜態常量成員變量(non-Integral type) //static const double csd2 = 99.9; // error: 只有靜態常量整型數據成員才可以在類中初始化 }; //注意下面三行:不能再帶有static int BClass::si = 0; // 靜態成員變量的初始化(Integral type) const int BClass::csi = 1; // 靜態常量成員變量的初始化(Integral type) const double BClass::csd = 99.9; // 靜態常量成員變量的初始化(non-Integral type) // 在初始化(1)中的csi2時,根據著名大師Stanley B.Lippman的說法下面這行是必須的。 // 但在VC2003中如果有下面一行將會產生錯誤,而在VC2005中,下面這行則可有可無,這個和編譯器有關。 const int BClass::csi2; int main() { BClass b; return 0; }
下面再說說成員變量是引用的情況:
因為引用是別名的意思,所以定義應用肯定是外部有定義,然後在構造函數初始化列表中被初始化的
#includeusing namespace std; class A { public: A(int i=3):m_i(i){} void print() { cout<<"m_i="<
這樣B中就可以有a這個對象了,[注意]:引用類型成員變量的初始化:
1,不能直接在構造函數裡初始化,必須用到初始化列表,且形參也必須是引用類型。
2,凡是有引用類型的成員變量的類,不能有缺省構造函數。原因是引用類型的成員變量必須在類構造時進行初始化。
3,如果兩個類要對第三個類的數據進行共享處理,可以考慮把第三個類作為這兩個類的引用類型的成員變量。