0

クラスのインスタンスのポインターを渡し、そのメンバー関数を取得してリストに保存できるかどうかを知りたいです。どうすればいいですか?

4

2 に答える 2

0

長い答えです。これは、C++チュートリアル ページの関数ポインターのチュートリアルです。

簡単な答えです。関数ポインターを配列に格納する例を次に示します。コンパイルされていないことに注意してください。

typedef void(*pFunc)(void); //pFunc is an alias for the function pointer type
void foo1(){};
void foo2(){}
int main(){
  pFunc funcs[2] = {&foo1, &foo2}; //hold an array of functions 
}

現在、メンバー関数は少し異なる構文です:

struct Foo{
  void foo1(){}
  void foo2(){}
}

typedef (*Foo::pFunc)(); //pFunc is an alias to member function pointer

int main(){
  pFunc funcs[2] = {&Foo::foo1, &Foo::foo2};
}

あなたの最善の策は、私がここに置いたリンクをチェックすることです. 構文などについて詳しく説明します。新しい C++11 を使用している場合は、std::function を使用できます。ブーストがある場合は、boost::function を使用できます。

于 2012-12-04T04:20:23.973 に答える
0

簡単な方法は、いくつかのテンプレート マジックと継承を使用することです。

template<class R>
class Base {
public:
   virtual R Execute() const=0;
};

template<class R, class P1, class P2>
class Derived : public Base<R> { 
public:
   void set_params(P1 p1, P2 p2) { m_p1 = p1; m_p2 = p2; }
   R Execute() const { return Map(m_p1,m_p2); }
protected:
   virtual R Map(P1, P2) const=0;
private:
  P1 m_p1;
  P2 m_p2;
};

template<class T, class R, class P1, class P2>
class MemFunc : public Derived<R,P1,P2> {
public:
   MemFunc(T *object, R (T::*fptr)(P1, P2)) : object(object), fptr(fptr) { }
   virtual R Map(P1 p1, P2 p2) const { return (object->*fptr)(p1,p2); }
private:
   T *object;
   R (T::*fptr)(P1,P2);
};

main() 関数は次のようになります。

int main() {
   std::vector<Base<int>*> vec;
   Object o;
   Derived<int, float,float> *ptr = new MemFunc(&o, &Object::MyFunc);
   ptr->set_params(10.0,20.0);
   vec.push_back(ptr);
   int i = vec[0].Execute();
}

クラスのすべてのメンバー関数を格納したい場合は、いくつかのベクトルが必要です。

std::vector<Base<int>*> vec_int;
std::vector<Base<float>*> vec_float;
std::vector<Base<MyObject>*> vec_myobject;
于 2012-12-04T03:42:40.950 に答える