如何使用成员函数初始化\`std::function\`?

新手上路,请多包涵

我正在尝试学习 std::function 这是我的代码:

 #include <iostream>
#include <functional>

struct Foo {
    void print_add(int i){
      std::cout << i << '\n';
    }
};

typedef std::function<void(int)> fp;

void test(fp my_func)
{
  my_func(5);
}

int main(){
    Foo foo;
    test(foo.print_add);
    return 0;
}

编译器错误:

  error: cannot convert 'Foo::print_add' from type 'void (Foo::)(int)' to type 'fp {aka std::function<void(int)>}'
     test(foo.print_add);

我怎样才能使这项工作,即我怎样才能将成员函数作为参数传递?

原文由 Kam 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 687
1 个回答

print_addfoo 的非静态成员函数,这意味着它必须在 Foo 的实例上调用;因此它有一个隐含的第一个参数, this 指针。

使用捕获 foo 实例并在其上调用 print_add 的 lambda。

 Foo foo;
test([&foo](int i){ foo.print_add(i); });

另一种选择是使用 std::bind 绑定 foo 实例:

 test(std::bind(&Foo::print_add, &foo, std::placeholders::_1));

现场演示

原文由 Praetorian 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题