有些成員變數的資料型別比較特別,它們的初始化方式也和普通資料型別的成員變數有所不同。這些特殊的型別的成員變數包括:
a.引用
b.常量
c.靜態
d.靜態常量(整型)
e.靜態常量(非整型)
常量和引用,必須通過引數列表進行初始化。
靜態成員變數的初始化也頗有點特別,是在類外初始化且一定不能再帶有
static
關鍵字。
靜態常量整型資料成員變數的初始化(integraltype) 有兩種方式,在類定義內或者在類定義體外如普通靜態成員變數一樣。
靜態常量非整型資料成員變數的初始化(non-integraltype) 只有一種方式,就是如普通靜態成員變數一樣在類外初始化。
#include
using namespace std;
class bclass
public:
bclass() : i(1), ci(2), ri(i){} // 對於常量型成員變數和引用型成員變數,必須通過引數化列表的方式進行初始化
//普通成員變數也可以放在函式體裡,但是本質其實已不是初始化,而是一種普通的運算操作-->賦值運算,效率也低
//這裡注意一下帶引數初始化列表的的建構函式的寫法,在類的定義裡寫了一下,不用像其他成員函式那樣再在外面再實現了。
private:
inti; // 普通成員變數
const int ci; // 常量成員變數
int&ri; // 引用成員變數
static int si; // 靜態成員變數
//static int si2 = 100; // error: 只有靜態常量成員變數,才可以這樣初始化
static const int csi; // 靜態常量成員變數
staticconst int csi2 = 100; // 靜態常量成員變數的初始化(integraltype) (1)
static const double csd; // 靜態常量成員變數(non-integraltype)
//static const double csd2 = 99.9; // error: 只有靜態常量整型資料成員才可以在類中初始化
//注意下面三行:不能再帶有static
int bclass::si = 0; // 靜態成員變數的初始化(integraltype)
const int bclass::csi = 1; // 靜態常量成員變數的初始化(integraltype) (2)
const double bclass::csd = 99.9; // 靜態常量成員變數的初始化(non-integraltype)
// 在初始化(1)中的csi2時,根據著名大師stanleyb.lippman的說法下面這行是必須的。
// 但在vc2003中如果有下面一行將會產生錯誤,而在vc2005中,下面這行則可有可無,這個和編譯器有關。
const int bclass::csi2;
int main()
bclass b;
return 0;
靜態成員屬於類作用域,但不屬於類物件,和普通的static變數一樣,程式一執行就分配記憶體並初始化,生命週期和程式一致。
所以,在類的建構函式裡初始化static變數顯然是不合理的。
靜態成員其實和全域性變數地位是一樣的,只不過編譯器把它的使用限制在類作用域內(不是類物件,它不屬於類物件成員),要在類的定義外(不是類作用域外)初始化。
類中特殊成員變數的初始化
有些成員變數的資料型別比較特別,它們的初始化方式也和普通資料型別的成員變數有所不同。這些特殊的型別的成員變數包括 a.常量型成員變數 b.引用型成員變數 c.靜態成員變數 d.整型靜態常量成員變數 e.非整型靜態常量成員變數 對於常量型及引用型成員變數,由於這兩種型別不支援賦值操作,因此必須通過建構...
類成員變數初始化
在 c 中,類的成員變數未初始化問題,取決於物件建立方式,不同的建立方式,直接導致類成員變數的初值不同。本文通過下例,得出一下結論 1.在函式體內置立乙個物件,類成員變數和普通的區域性變數一樣,是乙個隨機值。2.建立乙個全域性成員物件,類成員變數和全域性變數一樣,編譯器賦值為 0。3.在函式體內 n...
c 類的成員變數初始化
最近在做乙個關於boost的專案,修改將原本的多個commandline進行合併精簡,合併成乙個path路徑,然後再加上不同的hardcode的檔名組成乙個完整的路徑。由於在使用ptree時會呼叫靜態方法建立乙個instance的類,因此這裡需要使用靜態成員變數。大概整理了一下以前沒有注意過的類的成...