轉(zhuǎn)載自:
http://blog.csdn.net/akirya/archive/2009/01/18/3825040.aspx
很多人對(duì)成員函數(shù)指針有無(wú)解,以為成員函數(shù)指針同普通的函數(shù)指針區(qū)別不大,多了一個(gè)參數(shù).
然而實(shí)際上卻不是.多了個(gè)參數(shù),是不假,但他確實(shí)不是指針,雖說(shuō)名字中有指針兩個(gè)字,但實(shí)際上卻不是指針.
先看看最簡(jiǎn)單的使用
class test
{
public:
void func(){printf("call test::func\n");};
};
int main()
{
void(test::*p)() = &test::func;
test x;
(x.*p)();
}
這里的用法是最常見(jiàn)的,跟普通的函數(shù)指針使用的地方也差不多。一般見(jiàn)到的地方也差不多都這么用。
但成員函數(shù)指針還有更好用的地方,看下面這個(gè)例子
class base
{
public:
virtual void func(){printf("call base::func\n");};
};
class test:public base
{
public:
void func(){printf("call test::func\n");};
};
int main()
{
void(base::*p)() = &base::func;
test x;
(x.*p)();//調(diào)用的是test::func;
base y;
(y.*p)();//調(diào)用的是base::func;
}
從這個(gè)例子看,成員函數(shù)指針也可以使用多態(tài)。看到這里是不是覺(jué)得成員函數(shù)指針跟之前想的不一樣?
緊接著上面的例子,只更改main函數(shù)的內(nèi)容
int main()
{
void(base::*p)() = &base::func;
printf("sizeof( void(base::*p)()) %d\n" , sizeof(p) );
};
這里的輸出結(jié)果能想到么?(我的系統(tǒng)是32位的XP)
VC9 下是 4
GCC4.2.1 是 8
CodeGear C++ 6.10 的結(jié)果是12
到這里是不是會(huì)想到如何得到成員函數(shù)的地址呢?
我想到最簡(jiǎn)單的辦法就是輸出map文件,這樣就直接找到對(duì)應(yīng)的函數(shù)的地址。
那運(yùn)行時(shí)候怎么得到呢?
我的答案是沒(méi)有,
如果是虛函數(shù)則可以通過(guò)搜索虛表來(lái)得到,不過(guò)這個(gè)方法太不通用,也很難實(shí)際應(yīng)用。算是一種理論上能,但不能實(shí)際應(yīng)用的方法。
非虛函數(shù)的話(huà),還不知道有什么好的方法能夠得到。
發(fā)表于 @ 2009年01月18日 10:19:00|評(píng)論(loading...
)|收藏
posted on 2009-03-18 11:06
Alex-Lee 閱讀(1067)
評(píng)論(0) 編輯 收藏 引用