如何将成员函数指针转换为静态函数?
这是我的代码:
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);
}
答案 0 :(得分:2)
你可以std::bind
到相关类的实例:
auto func1 = std::bind(&ClassA::func, a);
func1();
这会将成员函数Class::func
绑定到a
。同样地:
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);
在这两种情况下,func1
和func2
实际上并不是函数指针,但它们的行为与它们相似。从std::bind
和std::mem_fn
返回的类型是实现定义的。但是,它们都可以转换为std::function
。
答案 1 :(得分:-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);
已解决
:)