声明函数指针需要多少内存。如何将函数指针指向类的成员函数?
[编辑:]我想我的问题不明确。我知道一个成员函数的函数指针占用更多的内存空间,我想知道为什么......
答案 0 :(得分:4)
答案取决于平台。您可以使用sizeof
找到特定平台的答案。
指向成员函数的指针的大小可能不一定与常规函数指针的大小相同,因此您应该编写一个测试来输出它们:
#include <iostream>
using namespace std;
void foo() {}
struct C {
void bar();
};
int main() {
cout << sizeof(&foo) << endl;
cout << sizeof(&C::bar) << endl;
return 0;
}
答案 1 :(得分:1)
它取决于实现,但通常指向成员函数的指针占用常规指针占用的相同空间量,加上this
指针所需的空间量。 ,通常与指针大小相同。因此,您希望指向成员函数的指针的大小是常规指针的两倍。
考虑:
#include <iostream>
using namespace std;
class Base
{
public:
int q;
Base() { ; }
void BaseFunc () { cout << this << endl; }
};
class Derived : public Base
{
public:
int r;
Derived() { ; }
virtual void DerivedFunc () { cout << this << endl; }
};
int main ()
{
Derived f;
f.BaseFunc();
f.DerivedFunc();
void (*p1)();
void (Derived::*p2)();
cout << sizeof(p1) << " " << sizeof(p2) << endl;
}
示例输出:
0x7fffe4c3e328
0x7fffe4c3e320
8 16
因此,指向成员函数的指针必须存储两条信息 - 调用函数以及如何调整this
指针以指向成员数据的右侧部分。
对于那些认为可以根据类型计算调整器的人,试试这个main
:
int main ()
{
Derived f;
void (Derived::*p1)();
p1 = &Derived::BaseFunc;
(f.*p1)();
p1 = &Derived::DerivedFunc;
(f.*p1)();
}
(f.*p1)();
的两次调用需要不同的调整器,即使类型相同。当然,通过BaseFunc
指针调用Base::(*)()
将需要不同的调整器通过Derived::(*)()
指针调用相同的函数。