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,你可以使用 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 回答