C++ 指向類成員的指針
前面曾寫過一篇惱人的函數(shù)指針(一),總結(jié)了普通函數(shù)指針的聲明、定義以及調(diào)用,還有函數(shù)指針數(shù)組,函數(shù)指針用作返回值等。但是作為C++的研讀,我發(fā)現(xiàn)我漏掉了一個(gè)最重要的內(nèi)容,就是指向類成員的指針,這里將做相應(yīng)補(bǔ)充(相關(guān)代碼測(cè)試環(huán)境為vs 2010)。
指向類成員的指針總的來講可以分為兩大類四小類(指向數(shù)據(jù)成員還是成員函數(shù),指向普通成員還是靜態(tài)成員),下面一一做介紹:
一、指向類的普通成員的指針(非靜態(tài))
1、指向類成員函數(shù)的指針
簡(jiǎn)單的講,指向類成員函數(shù)的指針與普通函數(shù)指針的區(qū)別在于,前者不僅要匹配函數(shù)的參數(shù)類型和個(gè)數(shù)以及返回值類型,還要匹配該函數(shù)指針?biāo)鶎俚念愵愋???偨Y(jié)一下,比較以下幾點(diǎn):
a)參數(shù)類型和個(gè)數(shù)
b)返回值類型
c)所屬的類類型(特別之處)
究其原因,是因?yàn)榉庆o態(tài)的成員函數(shù)必須被綁定到一個(gè)類的對(duì)象或者指針上,才能得到被調(diào)用對(duì)象的this指針,然后才能調(diào)用指針?biāo)傅某蓡T函數(shù)(我們知道,所有類的對(duì)象都有自己數(shù)據(jù)成員的拷貝,但是成員函數(shù)都是共用的,為了區(qū)分是誰調(diào)用了成員函數(shù),就必須有this指針,this指針是隱式的添加到函數(shù)參數(shù)列表里去的)。
明白了這點(diǎn),接下來就簡(jiǎn)單了。
聲明:與普通函數(shù)作為區(qū)分,指向類的成員函數(shù)的指針只需要在指針前加上類類型即可,格式為:
typedef 返回值 (類名::*指針類型名)(參數(shù)列表);
賦值:只需要用類的成員函數(shù)地址賦值即可,格式為:
指針類型名 指針名 = &類名::成員函數(shù)名;
注意:這里的這個(gè)&符號(hào)是比較重要的:不加&,編譯器會(huì)認(rèn)為是在這里調(diào)用成員函數(shù),所以需要給出參數(shù)列表,否則會(huì)報(bào)錯(cuò);加了&,才認(rèn)為是要獲取函數(shù)指針。這是C++專門做了區(qū)別對(duì)待。
調(diào)用:調(diào)用方法也很簡(jiǎn)單,針對(duì)調(diào)用的對(duì)象是對(duì)象還是指針,分別用.*和->*進(jìn)行調(diào)用,格式為:
(類對(duì)象.*指針名)(參數(shù)列表);
(類指針->*指針名)(參數(shù)列表);
注意:這里的前面一對(duì)括號(hào)是很重要的,因?yàn)?)的優(yōu)先級(jí)高于成員操作符指針的優(yōu)先級(jí)。
下面舉個(gè)簡(jiǎn)單的例子就一目了然了:
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); //通過對(duì)象調(diào)用 A *aPtr = new A; (aPtr->*funcPtr)(10); //通過指針調(diào)用 return 0; }
2、指向類數(shù)據(jù)成員的指針
成員函數(shù)搞懂了,數(shù)據(jù)成員也就easy了,只要判斷以下兩點(diǎn)是否一致即可:
a)數(shù)據(jù)成員類型
b)所屬的類類型
另外,聲明、賦值還有調(diào)用方法等這些是和前面類似的,再舉個(gè)例子吧:
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; //通過對(duì)象引用 A *aPtr = new A(100); cout<<aPtr->*dataPtr; //通過指針引用 return 0; }
運(yùn)行結(jié)果,當(dāng)然是各自輸出10和100啦。
二、指向類的靜態(tài)成員的指針
類的靜態(tài)成員和普通成員的區(qū)別在于,他們是不依賴于具體對(duì)象的,所有實(shí)例化的對(duì)象都共享同一個(gè)靜態(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; }
最后注明一下,顯然的,要使用(&類名::成員名)獲取指向成員的指針,首先這個(gè)成員必須是對(duì)外可見的哦,即public的,不然是沒有權(quán)限獲取的^^。
寫到此,簡(jiǎn)單總結(jié)一下就是:
1)靜態(tài)的和普通的函數(shù)指針沒啥區(qū)別;
2)非靜態(tài)的加一個(gè)類局限一下即可。
不知道以后還會(huì)不會(huì)有函數(shù)指針相關(guān)的內(nèi)容,先到此完結(jié)吧。
有錯(cuò)誤歡迎指正,我會(huì)及時(shí)修改^^。
(完)
以上就是C++ 指向類成員的指針的詳細(xì)內(nèi)容,更多關(guān)于C++指針的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C++利用 _findfirst與_findnext查找文件的方法
這篇文章主要給大家介紹了關(guān)于C++利用 _findfirst與_findnext查找文件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06C++面試題之?dāng)?shù)a、b的值互換(不使用中間變量)
這篇文章主要介紹了不使用中間變量,C++實(shí)現(xiàn)數(shù)a、b的值互相轉(zhuǎn)換操作,感興趣的小伙伴們可以參考一下2016-07-07C++對(duì)Json數(shù)據(jù)的友好處理實(shí)現(xiàn)過程
在Ajax的應(yīng)用中,前臺(tái)基本上會(huì)用到JSON作為數(shù)據(jù)交換格式,所以下面這篇文章主要給大家介紹了關(guān)于C++對(duì)Json數(shù)據(jù)的友好處理,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-02-02C++有限狀態(tài)機(jī)實(shí)現(xiàn)詳解
這篇文章主要為大家詳細(xì)介紹了C++有限狀態(tài)機(jī)的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10