函数指针内存使用情况

时间:2015-03-21 21:19:50

标签: c++ memory function-pointers

声明函数指针需要多少内存。如何将函数指针指向类的成员函数?

[编辑:]我想我的问题不明确。我知道一个成员函数的函数指针占用更多的内存空间,我想知道为什么......

2 个答案:

答案 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;
}

Demo.

答案 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::(*)()指针调用相同的函数。