4

私の質問はこれに似ています。そして、「カレック 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&& ...)

事前にt​​hx!:)

4

1 に答える 1

1

addMF の定義で Args&& を Args& に変更するか、呼び出し時に val を move(val) に変更します。

于 2013-03-22T02:28:22.213 に答える