C++ 指向類成員的指針
前面曾寫過一篇惱人的函數(shù)指針(一),總結(jié)了普通函數(shù)指針的聲明、定義以及調(diào)用,還有函數(shù)指針數(shù)組,函數(shù)指針用作返回值等。但是作為C++的研讀,我發(fā)現(xiàn)我漏掉了一個最重要的內(nèi)容,就是指向類成員的指針,這里將做相應(yīng)補充(相關(guān)代碼測試環(huán)境為vs 2010)。
指向類成員的指針總的來講可以分為兩大類四小類(指向數(shù)據(jù)成員還是成員函數(shù),指向普通成員還是靜態(tài)成員),下面一一做介紹:
一、指向類的普通成員的指針(非靜態(tài))
1、指向類成員函數(shù)的指針
簡單的講,指向類成員函數(shù)的指針與普通函數(shù)指針的區(qū)別在于,前者不僅要匹配函數(shù)的參數(shù)類型和個數(shù)以及返回值類型,還要匹配該函數(shù)指針?biāo)鶎俚念愵愋汀?偨Y(jié)一下,比較以下幾點:
a)參數(shù)類型和個數(shù)
b)返回值類型
c)所屬的類類型(特別之處)
究其原因,是因為非靜態(tài)的成員函數(shù)必須被綁定到一個類的對象或者指針上,才能得到被調(diào)用對象的this指針,然后才能調(diào)用指針?biāo)傅某蓡T函數(shù)(我們知道,所有類的對象都有自己數(shù)據(jù)成員的拷貝,但是成員函數(shù)都是共用的,為了區(qū)分是誰調(diào)用了成員函數(shù),就必須有this指針,this指針是隱式的添加到函數(shù)參數(shù)列表里去的)。
明白了這點,接下來就簡單了。
聲明:與普通函數(shù)作為區(qū)分,指向類的成員函數(shù)的指針只需要在指針前加上類類型即可,格式為:
typedef 返回值 (類名::*指針類型名)(參數(shù)列表);
賦值:只需要用類的成員函數(shù)地址賦值即可,格式為:
指針類型名 指針名 = &類名::成員函數(shù)名;
注意:這里的這個&符號是比較重要的:不加&,編譯器會認為是在這里調(diào)用成員函數(shù),所以需要給出參數(shù)列表,否則會報錯;加了&,才認為是要獲取函數(shù)指針。這是C++專門做了區(qū)別對待。
調(diào)用:調(diào)用方法也很簡單,針對調(diào)用的對象是對象還是指針,分別用.*和->*進行調(diào)用,格式為:
(類對象.*指針名)(參數(shù)列表);
(類指針->*指針名)(參數(shù)列表);
注意:這里的前面一對括號是很重要的,因為()的優(yōu)先級高于成員操作符指針的優(yōu)先級。
下面舉個簡單的例子就一目了然了:
class A;
typedef void (A::*NONSTATICFUNCPTR)(int); //typedef
class A
{
public:
void NonStaticFunc(int arg)
{
nonStaticMember = arg;
cout<<nonStaticMember<<endl;
}
private:
int nonStaticMember;
};
int main()
{
NONSTATICFUNCPTR funcPtr= &A::NonStaticFunc;
A a;
(a.*funcPtr)(10); //通過對象調(diào)用
A *aPtr = new A;
(aPtr->*funcPtr)(10); //通過指針調(diào)用
return 0;
}
2、指向類數(shù)據(jù)成員的指針
成員函數(shù)搞懂了,數(shù)據(jù)成員也就easy了,只要判斷以下兩點是否一致即可:
a)數(shù)據(jù)成員類型
b)所屬的類類型
另外,聲明、賦值還有調(diào)用方法等這些是和前面類似的,再舉個例子吧:
class A;
typedef int (A::*NONSTATICDATAPTR); //typedef
class A
{
public:
A(int arg):nonStaticMember(arg){}
int nonStaticMember;
};
int main()
{
NONSTATICDATAPTR dataPtr= &A::nonStaticMember;
A a(10);
cout<<a.*dataPtr; //通過對象引用
A *aPtr = new A(100);
cout<<aPtr->*dataPtr; //通過指針引用
return 0;
}
運行結(jié)果,當(dāng)然是各自輸出10和100啦。
二、指向類的靜態(tài)成員的指針
類的靜態(tài)成員和普通成員的區(qū)別在于,他們是不依賴于具體對象的,所有實例化的對象都共享同一個靜態(tài)成員,所以靜態(tài)成員也沒有this指針的概念。
所以,指向類的靜態(tài)成員的指針就是普通的指針。
看下面的例子就明白了:
typedef const int *STATICDATAPTR;
typedef int (*STATICFUNCPTR)(); //跟普通函數(shù)指針是一樣的
class A
{
public:
static int StaticFunc() { return staticMember; };
static const int staticMember = 10;
};
int main()
{
STATICDATAPTR dataPtr = &A::staticMember;
STATICFUNCPTR funcPtr = &A::StaticFunc;
cout<<*dataPtr; //直接解引用
cout<<(*funcPtr)();
return 0;
}
最后注明一下,顯然的,要使用(&類名::成員名)獲取指向成員的指針,首先這個成員必須是對外可見的哦,即public的,不然是沒有權(quán)限獲取的^^。
寫到此,簡單總結(jié)一下就是:
1)靜態(tài)的和普通的函數(shù)指針沒啥區(qū)別;
2)非靜態(tài)的加一個類局限一下即可。
不知道以后還會不會有函數(shù)指針相關(guān)的內(nèi)容,先到此完結(jié)吧。
有錯誤歡迎指正,我會及時修改^^。
(完)
以上就是C++ 指向類成員的指針的詳細內(nèi)容,更多關(guān)于C++指針的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Win10下最新版CLion(2020.1.3)安裝及環(huán)境配置教程詳解
這篇文章主要介紹了Win10下最新版CLion(2020.1.3)安裝及環(huán)境配置,CLion 是 JetBrains 推出的全新的 C/C++ 跨平臺集成開發(fā)環(huán)境,本文給大家介紹的非常詳細,需要的朋友可以參考下2020-08-08

