我已阅读here关于 boost:bind 是如何工作的,尤其是它 - 除了其他东西 - 生成这样的东西:
struct unspecified_type
{
... some members ...
return_type operator()(int i) const { return instance->*&klass::member(0, i);
}
现在,我正在寻找允许向实例指针添加额外间接的东西,以便它最终看起来像这样:
struct unspecified_type
{
... some members ...
return_type operator()(int i) const { return (*p_instance)->*&klass::member(0, i);
}
可以像这样使用
MyClass* pmc;
auto mfp = boost::bind(&MyClass::some_func, &pmc);
pmc = new MyClass();
mfp();
pmc = new MyClass();
mfp();
最佳答案
您可以使用 std::bind
和 std::ref
或它们的 boost 等效项(但由于您使用的是 C++11,因此您可能需要使用标准类和函数)。所以给定这个类:
#include <iostream>
struct MyClass
{
int x;
MyClass(int x_) : x(x_) { }
void some_func()
{
std::cout << x << std::endl;
}
};
您可以传递将要调用的成员函数封装在 std::reference_wrapper
中的指针。另外,避免使用new
(和delete
!),而更喜欢使用智能指针来建模对象所有权:
#include <functional>
#include <memory>
int main(int argc, char *argv[])
{
std::shared_ptr<MyClass> pmc;
auto mfp = std::bind(&MyClass::some_func, std::ref(pmc));
pmc = std::make_shared<MyClass>(42);
mfp();
pmc = std::make_shared<MyClass>(1729);
mfp();
}
这是一个live example .
关于c++ - 是否可以 boost::bind 到已知类但(尚)未知对象的成员函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16608723/