类成员函数类型声明和变量定义
c++ 成员函数地址声明方式和定义如下:
类型声明:typedef void (MyClass::*pFunType)(); 或using pFunType2 = void (MyClass::*)();
变量定义:void (MyClass::*p1)();
例子:
class MyClass
{
public:
void Show(){}
};
int main()
{
typedef void (MyClass::*pFunType)();
using pFunType2 = void (MyClass::*)();
void (MyClass::*p1)();
p1 = &MyClass::Show;
pFunType p2 = &MyClass::Show;
pFunType2 p3 = &MyClass::Show;
return 0;
}
类成员函数使用
类成员函数使用需要3个特殊运算符: ::* .* 和 ->*
在类型声明时需要使用 ::* 比如: void (MyClass::*p1)();
使用时需要.* 和 ->* 比如:MyClass a; (a.*p1)();
类成员函数的大小
指针大小32为下是4个字节,64位下是8个字节。然而类成员函数的大小呢?
gcc编译器5.4版本,类成员函数地址是void *大小的两倍。
vs 编译器在单继承或不继承的情况下函数地址大小和void*一样,多继承类成员函数地址是void *大小的两倍。
#include <iostream>
class IType {
public:
void Show1() {
}
};
class IType2 {
public:
void Show2() {
}
};
class MyClass : IType, IType2
{
public:
void Show3() {}
};
int main()
{
int a = sizeof(&MyClass::Show3);
std::cout << sizeof(void *) << "," << a << std::endl; //vs 下输出4,8。g++ 下输出4,8
return 0;
}
//vs 下输出4,8。g++ 下输出4,8
所以那些把类成员函数地址保存为void*兄弟都悲剧了。
有几篇文章写的挺不错的推荐一下:
作者翻译了一篇英文:https://kelvinh.github.io/blog/2014/03/27/cpp-tutorial-pointer-to-member-function/
讨论了编译器对函数地址的实现:https://blog.csdn.net/ym19860303/article/details/8586971