C++: Array of member function pointers to different functions

前端 未结 2 2002
滥情空心
滥情空心 2020-12-16 03:47

I have a class A which contains member functions foo() and bar() which both return a pointer to class B. How can I declare an array containing the functions foo and bar as a

相关标签:
2条回答
  • 2020-12-16 04:42

    The member function pointer syntax is ReturnType (Class::*)(ParameterTypes...), so e.g.:

    typedef B* (A::*MemFuncPtr)(); // readability
    MemFuncPtr mfs[] = { &A::foo, &A::bar }; // declaring and initializing the array
    B* bptr1 = (pointerToA->*mfs[0])(); // call A::foo() through pointer to A
    B* bptr2 = (instanceOfA.*mfs[0])(); // call A::foo() through instance of A
    

    See e.g. this InformIT article for more details on pointers to members.

    You might also want to look into Boost.Bind and Boost.Function (or their TR1 equivalents) which allow you to opaquely bind the member-function-pointers to an instance:

    typedef boost::function<B* ()> BoundMemFunc;
    A instanceOfA;
    BoundMemFunc mfs[] = { 
        boost::bind(&A::foo, &instanceOfA), 
        boost::bind(&A::bar, &instanceOfA) 
    };
    B* bptr = mfs[0](); // call A::foo() on instanceOfA
    

    To use such an array as a member, note that you can't initialize arrays using the member initializer list. Thus you can either assign to it in the constructor body:

    A::A {
        mfs[0] = &A::foo;
    }
    

    ... or you use a type that can actually be initialized there like std::vector or boost::array:

    struct A {
        const std::vector<MemFuncPtr> mfs;
        // ...
    };
    
    namespace {
        std::vector<MemFuncPtr> init_mfs() {
            std::vector<MemFuncPtr> mfs;
            mfs.push_back(&A::foo);
            mfs.push_back(&A::bar);
            return mfs;
        }
    }
    
    A::A() : mfs(init_mfs()) {}
    
    0 讨论(0)
  • 2020-12-16 04:46

    What you're looking for are pointers to member functions. Here is a short sample that shows their declaration and use:

    #include <iostream>
    
    class B {
    public:
      B(int foo): foo_(foo) {
        std::cout << "Making a B with foo_ = " << foo_ << std::endl;
      }
      ~B(void) {
        std::cout << "Deleting a B with foo_ = " << foo_ << std::endl;
      }
      int foo_;
    };
    
    class A {
    public:
      A(void) {
        funcs_[0] = &A::foo;
        funcs_[1] = &A::bar;
      }
    
      B* foo(void) {
        return new B(3);
      }
    
      B* bar(void) {
        return new B(5);
      }
    
      // Typedef for the member function pointer, for everyone's sanity.
      typedef B* (A::*BMemFun)(void);
      BMemFun funcs_[2];
    };
    
    int main(int argc, char *argv[]) {
      A a;
      for (int i = 0; i < 2; ++i) {
        A::BMemFun func = a.funcs_[i];
        // Call through the member function pointer (the .* operator).
        B* b = (a.*func)();
        delete b;
      }
      return 0;
    }
    

    The C++ FAQ section on pointers to member functions is where I found all this information.

    0 讨论(0)
提交回复
热议问题