類體中的資料成員的聲明前加上static關鍵字,該資料成員就成為了該類的待用資料成員。和其他資料成員一樣,待用資料成員也遵守public/protected/private訪問規則。同時,待用資料成員還具有以下特點:
1.C++待用資料成員的定義。
待用資料成員實際上是類域中的全域變數。所以,待用資料成員的定義(初始化)不應該被放在標頭檔中。
其定義方式與全域變數相同。舉例如下:
xxx.h檔案
1. class base{
2. private:
3. static const int _i;//聲明,標準c++支援有序類型在類體中初始化,但vc6不支援。
4. };
xxx.cpp檔案
1. const int base::_i=10; // 定義(初始化)時不受private和protected訪問限制.
註:不要試圖在標頭檔中定義(初始化)待用資料成員。在大多數的情況下,這樣做會引起重複定義這樣的錯誤。即使加上#ifndef #define #endif或者#pragma once也不行。
2.C++待用資料成員被類的所有對象所共用,包括該類衍生類別的對象。即衍生類別對象與基類對象共用基類的待用資料成員。 舉例如下:
1. class base{
2. public :
3. static int _num;//聲明
4. };
5. int base::_num=0;//待用資料成員的真正定義
6. class derived:public base{
7. };
8. main()
9. {
10. base a;
11. derived b;
12. a._num++;
13. cout<<"base class static data number _num is"<<a._num<<endl;
14. b._num++;
15. cout<<"derived class static data number _num is"<<b._num<<endl;
16. }
17. // 結果為1,2;可見衍生類別與基類共用一個待用資料成員。
3.C++待用資料成員可以成為成員函數的選擇性參數,而普通資料成員則不可以。 舉例如下:
1. class base{
2. public :
3. static int _staticVar;
4. int _var;
5. void foo1(int i=_staticVar);//正確,_staticVar為待用資料成員
6. void foo2(int i=_var);//錯誤,_var為普通資料成員
7. };
4.C++待用資料成員的類型可以是所屬類的類型,而普通資料成員則不可以。 普通資料成員的只能聲明為 所屬類類型的 指標或引用。舉例如下:
1. class base{
2. public :
3. static base _object1;//正確,待用資料成員
4. base _object2;//錯誤
5. base *pObject;//正確,指標
6. base &mObject;//正確,引用
7. };
5.這個特性,我不知道是屬於標準c++中的特性,還是vc6自己的特性。 C++待用資料成員的值在const成員函數中可以被合法的改變。舉例如下:
1. class base{
2. public:
3. base(){_i=0;_val=0;}
4. mutable int _i;
5. static int _staticVal;
6. int _val;
7. void test() const{//const 成員函數
8. _i++;//正確,mutable資料成員
9. _staticVal++;//正確,static資料成員
10. _val++;//錯誤
11.
12. }
13. };
14. int base::_staticVal=0;