2

如何将成员函数指针转换为静态函数?

这是我的代码:

class ClassA
{
public:
    int n;
    void func();
};
void ClassA::func()
{
    n = 89;
}

class ClassB
{
public:
    float f1;
    float f2;
    void func(float f);
};
void ClassB::func( float f )
{
    f1 += f;
    f2 += f;
}


int main (int argc, char *argv[]) 
{
    ClassA* a = new ClassA;
    ClassB* b = new ClassB;

    //PROBLEM IS HERE
    void (* pf_func1)(void*) = ClassA.func;
    void (* pf_func2)(void*, float) = ClassB.func;


    pf_func1(a);
    pf_func2(b, 10);
}
4

2 回答 2

2

您可以将std::bind其添加到相关类的实例中:

auto func1 = std::bind(&ClassA::func, a);
func1();

这将成员函数绑定Class::funca. 同样:

auto func2 = std::bind(&ClassB::func, b, std::placeholders::_1);
func2(10.0f);

或者,您可以使用std::mem_fn允许您轻松更改调用它的对象,提供您要求的语法:

auto func1 = std::mem_fn(&ClassA::func);
func1(a);
auto func2 = std::mem_fn(&ClassB::func);
func2(b, 10.0f);

并不是在这两种情况下func1func2实际上都不是函数指针,但它们的行为确实像它们。std::bind从和返回的类型std::mem_fn是实现定义的。但是,它们都可以转换为std::function.

于 2013-02-23T12:47:01.687 回答
-1
void(ClassA::*pf1)() = &ClassA::func;
void(ClassB::*pf2)(float) = &ClassB::func;
void (__thiscall * pf_func1)(void*) = (void (__thiscall *)(void*)) ((void*&)pf1);
void (__thiscall * pf_func2)(void*, float) = (void (__thiscall *)(void*, float)) ((void*&)pf2);

解决了

:)

于 2013-02-24T05:33:14.727 回答