调用对象类型'void(B :: *)(int)'不是函数或函数指针

问题描述 投票:4回答:1

我试图将传递方法作为函数参数包裹起来。这是一个简单的示例,它返回我不理解的编译错误

class B
{
private:
    int j;
public:
    void foo(int i){std::cout << i + this->j << std::endl;}
    void setj(int J){j=J;}
};

class A
{
private:
    B b;

public:
    void call(void (B::*fun)(int i), int i) { b.*fun(i); }
    void setBj(int j){b.setj(j);}
};


int main()
{
    A a;
    a.setBj(40);
    a.call(B::foo, 2);
}

编译时

g++ -std=c++11 b.cpp -o b

我明白了

b.cpp:22:50: error: called object type 'void (B::*)(int)' is not a function or
      function pointer
        void call(void (B::*fun)(int i), int i) { b.*fun(i); }
                                                     ~~~^
b.cpp:31:12: error: call to non-static member function without an object
      argument
        a.call(B::foo, 2);
               ~~~^~~
2 errors generated.

我不明白第一条错误消息。我知道我调用foo好像它是一个静态方法,但它不是,但我不明白如何传递一个非静态方法。

c++ function parameter-passing
1个回答
7
投票

两个问题。

  1. 要调用指向成员函数的指针,首先需要应用指向成员访问运算符的指针,该指针获取可调用表达式。然后你添加一个电话。现在碰巧.*的优先级低于函数调用运算符。所以第一个修复: (b.*fun)(i)
  2. 只能通过在完全限定的函数名上应用一元&来获取指向成员函数的指针。所以第二个修复: a.call(&B::foo, 2);
© www.soinside.com 2019 - 2024. All rights reserved.