如何将函数指针作为参数传递给重载的成员函数

How to pass a function pointer to overloaded member function as parameter

这与代码生成有关。

我有一个从模型生成的 class A,其中我有两个函数重载 f,如下所示:

class A
{
  public:
    void f(int a){}
    void f(int a, int b){}
}

然后我有一个独立的系统部分,它不是从模型生成的,而是用手工制作的 C++ 编写的。在这里,我想访问对象上的函数 f。我可以从模型将数据传递到系统的手工制作部分,但反之则不行,因为生成的文件在我构建手工制作的代码时不可用于编译。

我的想法是将函数指针从模型传递到我需要的地方。据我目前的理解,这包括 static_cast 来解决过载问题,然后我可以将指向该函数的指针作为参数传递给其他一些手工制作的函数。

用于将指针传递给系统手工制作部分的函数是这样声明的(这里A不知道):

void passPointer(int, void (*f)(int, int));

我的转换和函数调用如下所示:

handCraftedObject->passPointer(17, static_cast<void (A::*)(int, int)> (&A::f) );

我的编译错误是:

:   no known conversion for argument 2 from 'void (A::*)(int, int)' to 'void (*)(int, int)

我希望这并不意味着我必须知道 class A 声明传递函数指针的函数的位置。这在我的系统中是不可能的。

成员函数指针与函数指针的类型不同,无法转换为它。最简单的方法是使用 boost/std(C++11) bindfunction.

void passPointer(int, const std::function<void(int, int)>&);

不仅仅是

handCraftedObject->passPointer
(
   17, std::bind(static_cast<void (A::*)(int, int)> (&A::f), std::ref(a_instance), 
   std::placeholders::_1, std::placeholders::_2)
);

另外你不能使用boost/C++11,你可以make function f static,然后一切正常。