靜態類成員包括靜態數據成員和靜態函數成員兩部分。
1 靜態數據成員:
類體中的數據成員的聲明前加上static關鍵字,該數據成員就成為了該類的靜態數據成員。和其他數據成員一樣,靜態數據成員也遵守public/protected/private訪問規則。同時,靜態數據成員還具有以下特點:
1.靜態數據成員的定義。
靜態數據成員實際上是類域中的全局變量。所以,靜態成員不能在類定義里邊初始化,只能在class body外初始化。 舉例如下:
xxx.h文件
class base{
private:
static const int _i;//聲明,標準c++支持有序類型在類體中初始化,但vc6不支持。
};
xxx.cpp文件
const int base::_i=10;//定義(初始化)時不受private和protected訪問限制.
2.靜態數據成員被類的所有對象所共享,包括該類派生類的對象。即派生類對象與基類對象共享基類的靜態數據成員。
3 初始化(或定義),訪問方式
靜態數據成員初始化的格式為:
<數據類型><類名>::<靜態數據成員名>=<值>
類的靜態數據成員有兩種訪問形式:
<類對象名>.<靜態數據成員名> 或 <類類型名>::<靜態數據成員名>
如果靜態數據成員的訪問權限允許的話(即public的成員),可在程序中,按上述格式來引用靜態數據成員 ;
3.靜態數據成員可以成為成員函數的可選參數,而普通數據成員則不可以。舉例如下:
class base{
public :
static int _staticVar;
int _var;
void foo1(int i=_staticVar);//正確,_staticVar為靜態數據成員
void foo2(int i=_var);//錯誤,_var為普通數據成員
};
4.★靜態數據成員的類型可以是所屬類的類型,而普通數據成員則不可以。普通數據成員的只能聲明為 所屬類類型的指針或引用。舉例如下:
class base{
public :
static base _object1;//正確,靜態數據成員
base _object2;//錯誤
base *pObject;//正確,指針
base &mObject;//正確,引用
};
5.★這個特性,我不知道是屬于標準c++中的特性,還是vc6自己的特性。
靜態數據成員的值在const成員函數中可以被合法的改變。舉例如下:
class base{
public:
base(){_i=0;_val=0;}
mutable int _i;
static int _staticVal;
int _val;
void test() const{//const 成員函數
_i++;//正確,mutable數據成員
_staticVal++;//正確,static數據成員
_val++;//錯誤
}
};
int base::_staticVal=0;
2 靜態成員函數
1.靜態成員函數的地址可用普通函數指針儲存,而普通成員函數地址需要用 類成員函數指針來儲存。舉例如下:
class base{
static int func1();
int func2();
};
int (*pf1)()=&base::func1;//普通的函數指針
int (base::*pf2)()=&base::func2;//成員函數指針
2.靜態成員函數不可以調用類的非靜態成員。因為靜態成員函數不含this指針。
通常情況下,this 是缺省的。如函數fn()實際上是this->fn()。但是與普通函數相比,靜態成員函數由于不是與任何的對象相聯系,因此它不具有this指 針。從這個意義上講,它無法訪問屬于類對象的非靜態數據成員,也無法訪問非靜態成員函數,它只能調用其余的靜態成員函數。
3.靜態成員函數不可以同時聲明為 virtual、const、volatile函數。舉例如下:
class base{
virtual static void func1();//錯誤
static void func2() const;//錯誤
static void func3() volatile;//錯誤
};
3 靜態構造函數
靜態構造函數自動被調用,不能被顯式調用。雖然提供了許多約束條件,但是靜態構造函數執行的確切時間和順序是不確定的:
一個類的靜態構造函數在這個類的任何實例被創建前執行。
一個類的靜態構造函數在類的任何靜態成員被引用前執行。
一個類的靜態構造函數在它的所有派生類的靜態構造函數執行之后執行。
一個類的靜態構造函數從不會被執行一次以上。