C++中指向成員的指標
一個類有兩種基本的成員:函數成員和資料成員。同樣的,指向成員的指標也有兩種:指向函數成員的指標和指向資料成員的指標。後則其實並不常用,因為類一般是不含有公用資料成員的,僅當用在繼承用C寫的代碼時協調結構(struct)和類(class)時才會用到。
指向成員的指標是C++文法中最難以理解的構造之一,但是這也是一個C++最強大的特性。它可以讓你調用一個類的函數成員而不必知道這個函數的名字。這一個非常敏捷的調用工具。同樣的,你也可以通過使用指向資料成員的指標來檢查並改變這個資料而不必知道它的成員名字。
指向資料成員的指標
儘管剛開始時,指向成員的指標的文法會使你有一點點的迷惑,但你不久會發現它其實同普通的指標差不多,只不過是*號的前面多了::符號和類的名字,例:定義一個指向int型的指標:
int * pi;
定義一個指向為int型的類的資料成員:
int A::*pmi; //pmi是指向類A的一個int型的成員
你可以這樣初始化它:
class A
{
public:
int num;
int x;
};
/*
指向類資料成員的指標與普通指標的初始化及賦值方式不太一樣,因為普通指標在給其初始化或賦值時,賦予的是一個實際的對象,如 int j; int *i=&j;
而指向資料成員的指標賦予的是一個目前還不存在的一個類成員的地址,而這個地址只有在使用實際類對象進行調用時才會真正的確定下來,如下:
*/
int A::*pmi = & A::num;
上面的代碼是聲明一個指向類A的一個int型的num成員並將它初始化為這個num成員的地址.通過在pmi前面加上*你就可以使用和更改類A的num成員的值:
A a1, a2;
int n=a1.*pmi; //把a1.num賦值給n
a1.*pmi=5; // 把5賦值給a1.num
a2.*pmi=6; // 把6賦值給6a2.num
如果你定義了一個指向類A的指標,那麼上面的操作你必須用 ->*操作符代替:
A * pa=new A;
int n=pa->*pmi;
pa->*pmi=5;
指向函數成員的指標
它由函數成員所返回的資料類型構成,類名後跟上::符號、指標名和函數的參數列表。舉個例子:一個指向類A的函數成員(該函數返回int類型)的指標:
class A
{
public:
int func ();
};
int (A::*pmf) ();
上面的定義也就是說pmf是一個指向類A的函數成員func()的指標.實際上,這個指標和一個普通的指向函數的指標沒什麼不同,只是它包含了類的名字和::符號。你可以在在任何使用*pmf的地方調用這個函數
func():
pmf=&A::func;
A a;
(a.*pmf)(); //調用a.func()
如果你先定義了一個指向對象的指標,那麼上面的操作要用->*代替:
A *pa=&a;
(pa->*pmf)(); //調用pa->func()
指向函數成員的指標要考慮多態性。所以,當你通過指標調用一個虛函數成員時,這個調用將會被動態回收。另一個需要注意的地方,你不能取一個類的建構函式和解構函式的地址。