クラスのインスタンスのポインターを渡し、そのメンバー関数を取得してリストに保存できるかどうかを知りたいです。どうすればいいですか?
質問する
321 次
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 に答える