私の質問はこれに似ています。そして、「カレック SB の回答は、実際に私をいくらか助けてくれました。私はこれらのクラスを持っています:
Base.h:
class Base{
public:
Base(){}
virtual ~Base(){}
virtual void init() = 0;
};
A1.h:
#include <iostream>
#include "Base.h"
using namespace std;
class A1 : public Base{
public:
A1(){}
virtual ~A1(){};
virtual void init(){
cout << "A1::init() called" << endl;
}
void f1(){
cout << "Im in A1::f1" << endl;
}
void f2(int val){
cout << "Im in A1::f2 with val: " << val << endl;
}
};
任意の型と数の引数を持つ汎用メンバー関数を格納できる別のクラスがあります。クラスは次のようになります。
MFholder.h:
#include <functional>
#include <deque>
using namespace std;
class MFHolder{
public:
MFHolder(){};
~MFHolder(){};
template<typename T, typename R, typename ... Args>
R addMF(T & obj, R (T::*pf)(Args ...), Args&& ... args){
mfp.push_back(function<void()>(bind(pf, &obj, forward<Args>(args) ...)));
}
void runTasks(){
while(!mfp.empty()){
auto task = mfp.front();
mfp.pop_front();
task();
}
}
private:
deque< function<void()> > mfp;
};
ここで、次のようにメインから MFHolder にいくつかのメンバー関数を追加したいと思います: main.cpp:
#include "A1.h"
#include "MFHolder.h"
int main(){
MFHolder mfh;
A1 a1Obj;
//A2 a2Obj; //this should also work
int val = 42;
//mfh.addMF(a1Obj, &A1::f1); //this should also work
mfh.addMF(a1Obj, &A1::f2, val);
//add some more function calls here...
//run all the tasks
mfh.runTasks();
return 0;
}
コードをコンパイルすると、次のエラーが発生します。
の呼び出しに一致する関数がありません
'MFHolder::addMF(A1&, void (A1::*)(int), int&)'
そして候補は:
template<class T, class R, class ... Args> R MFHolder::addMF(T&, R (T::*)(Args ...), Args&& ...)
事前にthx!:)