C++静态成员函数小结
生活随笔
收集整理的這篇文章主要介紹了
C++静态成员函数小结
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
C++靜態成員函數小結
C++靜態成員函數小結
類中的靜態成員真是個讓人愛恨交加的特性。我決定好好總結一下靜態類成員的知識點,以便自己在以后面試中,在此類問題上不在被動。?
靜態類成員包括靜態數據成員和靜態函數成員兩部分。?一 靜態數據成員:?
類體中的數據成員的聲明前加上static關鍵字,該數據成員就成為了該類的靜態數據成員。和其他數據成員一樣,靜態數據成員也遵守public/protected/private訪問規則。同時,靜態數據成員還具有以下特點:?
1.靜態數據成員的定義。?
靜態數據成員實際上是類域中的全局變量。所以,靜態數據成員的定義(初始化)不應該被放在頭文件中。?
其定義方式與全局變量相同。舉例如下:?
xxx.h文件?
class base{?
private:?
static const int _i;//聲明,標準c++支持有序類型在類體中初始化,但vc6不支持。?
};?
xxx.cpp文件?
const int base::_i=10;//定義(初始化)時不受private和protected訪問限制.?
注:不要試圖在頭文件中定義(初始化)靜態數據成員。在大多數的情況下,這樣做會引起重復定義這樣的錯誤。即使加上#ifndef #define #endif或者#pragma once也不行。?
2.靜態數據成員被 類 的所有對象所共享,包括該類派生類的對象。即派生類對象與基類對象共享基類的靜態數據成員。舉例如下:?
class base{?
public :?
static int _num;//聲明?
};?
int base::_num=0;//靜態數據成員的真正定義?
class derived:public base{?
};?
main()?
{?
base a;?
derived b;?
a._num++;?
cout<<"base class static data number _num is"<<a._num<<endl;?
b._num++;?
cout<<"derived class static data number _num is"<<b._num<<endl;?
}?
// 結果為1,2;可見派生類與基類共用一個靜態數據成員。?
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;?
二,靜態成員函數?
靜態成員函數沒有什么太多好講的。?
1.靜態成員函數的地址可用普通函數指針儲存,而普通成員函數地址需要用 類成員函數指針來儲存。舉例如下:?
class base{?
static int func1();?
int func2();?
};?
int (*pf1)()=&base::func1;//普通的函數指針?
int (base::*pf2)()=&base::func2;//成員函數指針?
2.靜態成員函數不可以調用類的非靜態成員。因為靜態成員函數不含this指針。?
3.靜態成員函數不可以同時聲明為 virtual、const、volatile函數。舉例如下:?
class base{?
virtual static void func1();//錯誤?
static void func2() const;//錯誤?
static void func3() volatile;//錯誤?
};?
最后要說的一點是,靜態成員是可以獨立訪問的,也就是說,無須創建任何對象實例就可以訪問。
總結
以上是生活随笔為你收集整理的C++静态成员函数小结的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C++中mutable、volatile
- 下一篇: C++中构造函数和析构函数可以抛出异常吗