类成员函数指针是什么?
很多人对成员函数指针有无解,以为成员函数指针同普通的函数指针区别不大,多了一个参数.
然而实际上却不是.多了个参数,是不假,但他确实不是指针,虽说名字中有指针两个字,但实际上却不是指针.
先看看最简单的使用
class test
{
public:
void func(){printf("call test::func\n");};
};
int main()
{
void(test::*p)() = &test::func;
test x;
(x.*p)();
}
这里的用法是最常见的,跟普通的函数指针使用的地方也差不多。一般见到的地方也差不多都这么用。
但成员函数指针还有更好用的地方,看下面这个例子
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)();//调用的是test::func;
base y;
(y.*p)();//调用的是base::func;
}
从这个例子看,成员函数指针也可以使用多态。看到这里是不是觉得成员函数指针跟之前想的不一样?
紧接着上面的例子,只更改main函数的内容
int main()
{
void(base::*p)() = &base::func;
printf("sizeof( void(base::*p)()) %d\n" , sizeof(p) );
};
这里的输出结果能想到么?(我的系统是32位的XP)
VC9 下是 4
GCC4.2.1 是 8
CodeGear C++ 6.10 的结果是12
到这里是不是会想到如何得到成员函数的地址呢?
我想到最简单的办法就是输出map文件,这样就直接找到对应的函数的地址。
那运行时候怎么得到呢?
我的答案是没有,
如果是虚函数则可以通过搜索虚表来得到,不过这个方法太不通用,也很难实际应用。算是一种理论上能,但不能实际应用的方法。
非虚函数的话,还不知道有什么好的方法能够得到。