C++:通过指针调用成员函数

16

我有这个使用成员函数指针的示例代码,我想在运行时更改它,但我无法使它工作。我已经尝试了this->*_currentPtr(4,5)(*this)._currentPtr(4, 5)。调用同一类中的方法指针的正确方式是什么?

错误信息:表达式必须具有(指向)函数类型

#include <iostream>
#include <cstdlib>

class A {

public:

    void setPtr(int v);
    void useFoo();

private:
    typedef int (A::*fooPtr)(int a, int b);

    fooPtr _currentPtr;

    int foo1(int a, int b);
    int foo2(int a, int b);
};

void A::setPtr(int v){
    if(v == 1){
        _currentPtr = foo1;
    } else {
        _currentPtr = foo2;
    }
}

void A::useFoo(){

    //std::cout << this->*_currentPtr(4,5); // ERROR
}

int A::foo1(int a, int b){
    return a - b;
}

int A::foo2(int a, int b){
    return a + b;
}

int main(){

    A obj;

    obj.setPtr(1);
    obj.useFoo();

    return 0;
}

你遇到了哪些问题和错误信息? - Timo Geusch
1个回答

23
你需要告诉编译器这些foo来自哪个类(否则它会认为它们是来自全局范围的函数):

你需要告诉编译器这些foo来自哪个类(否则它会认为它们是来自全局范围的函数):

void A::setPtr(int v){
    if(v == 1){
        _currentPtr = &A::foo1;
                  //  ^^^^
    } else {
        _currentPtr = &A::foo2;
                  //  ^^^^
    }
}

并且你需要在这里加上一对括号:

std::cout << (this->*_currentPtr)(4,5);
          // ^                  ^

1
谢谢,这对我有帮助。但是我有点困惑,为什么需要&运算符呢?我以为函数被视为地址。 - ashur
2
@ashur 对于普通函数来说是正确的,但对于成员函数则不然。而后者并不是常规指针。 - jrok
2
@ashur 请查看这篇文章,了解成员指针的内部细节,非常有趣。 - jrok

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接