Присвоение указателей на функции C ++ функциям-членам одного и того же объекта - PullRequest
5 голосов
/ 01 февраля 2011

Как мне получить указатели на функции (и, может быть, остальные) в test.calculate для работы?

#include <iostream>

class test {

    int a;
    int b;

    int add (){
        return a + b;
    }

    int multiply (){
        return a*b;
    }

    public:
    int calculate (char operatr, int operand1, int operand2){
        int (*opPtr)() = NULL;

        a = operand1;
        b = operand2;

        if (operatr == '+')
            opPtr = this.*add;
        if (operatr == '*')
            opPtr = this.*multiply;

        return opPtr();
    }
};

int main(){
    test t;
    std::cout << t.calculate ('+', 2, 3);
}

Ответы [ 2 ]

10 голосов
/ 01 февраля 2011

Есть несколько проблем с вашим кодом.

Во-первых, int (*opPtr)() = NULL; не указатель на функцию-член, это указатель на свободную функцию.Объявите указатель на функцию-член следующим образом:

int (test::*opPtr)() = NULL;

Во-вторых, вам нужно указать область действия класса, когда принимает адрес функции-члена, например:

if (operatr == '+') opPtr = &test::add;
if (operatr == '*') opPtr = &test::multiply;

Наконец, для вызова через указатель на функцию-член существует специальный синтаксис:

return (this->*opPtr)();

Вот полный рабочий пример:

#include <iostream>

class test {

    int a;
    int b;

    int add (){
        return a + b;
    }

    int multiply (){
        return a*b;
    }

    public:
    int calculate (char operatr, int operand1, int operand2){
        int (test::*opPtr)() = NULL;

        a = operand1;
        b = operand2;

        if (operatr == '+') opPtr = &test::add;
        if (operatr == '*') opPtr = &test::multiply;

        return (this->*opPtr)();
    }
};

int main(){
    test t;
    std::cout << t.calculate ('+', 2, 3);
}
3 голосов
/ 01 февраля 2011

Как это int (test::*opPtr)() = NULL;.См. http://www.parashift.com/c++-faq-lite/pointers-to-members.html#faq-33.1

Редактировать: Также используйте if (operatr == '+') opPtr = &test::add; вместо [..] = this.<em>add и return (this-></em>(opPtr))(); вместо return opPtr();.Фактически, используйте typedefs и макросы, как указано в FAQ, и, возможно, параметры-члены-функции вместо членов класса a и b.

...