如何std::bind一个智能指针return方法?
How to std::bind a smart pointer return method?
所以我的 Bar
class:
中有这个方法
std::shared_ptr<sf::Sprite> Bar::getStuff() const
{
//...
}
我有我的回调类型定义:
typedef std::function<void()> Callback;
void Foo::registerCallback(const Callback& callback)
{
//...
}
现在我想在这个方法上使用 std::bind
,例如:
Foo foo;
Bar bar; //I create an instance of an Bar, called bar.
foo.registerCallback(std::bind(&Bar::getStuff, std::ref(bar))); //<--- ERROR!!!!
错误:
error C2562: 'std::_Callable_obj<std::_Bind<true,std::shared_ptr<sf::Sprite>,std::_Pmf_wrap<std::shared_ptr<sf::Sprite> (__thiscall Bar::* )(void)
如果我想使用void方法,没问题。但是我需要使用 getStuff()
方法,它将 return 变成 smart pointer
到 sf::Sprite 东西。
我怎样才能做到这一点?
鉴于您使用的是 c++11,为什么不用 lambda?
foo.registerCallback([&bar]() { bar.getStuff(); });
。您的错误来自您的称呼方式。 Bar::getStuff
returns 你试图丢弃的东西。你只能在 discard 表达式和语句中丢弃东西。
一个解决方案
template<class Callable>
auto discard_callable(Callable&& callable)
{ return [=]() { (void) callable(); }; }
你可以这样使用它:
foo.registerCallback(discard_callable(
std::bind(&Bar::getStuff, std::cref(bar))
));
MCVE
#include <functional>
#include <string>
struct Butler
{
std::string say() const { return "Welcome home, Sir."; }
};
template<class Callable>
auto discard_callable(Callable&& callable)
{ return [=]() { (void) callable(); }; }
int main()
{
Butler igor;
std::function<void()> welcome = discard_callable(std::bind(&Butler::say, std::ref(igor))); // error without discard
welcome();
}
所以我的 Bar
class:
std::shared_ptr<sf::Sprite> Bar::getStuff() const
{
//...
}
我有我的回调类型定义:
typedef std::function<void()> Callback;
void Foo::registerCallback(const Callback& callback)
{
//...
}
现在我想在这个方法上使用 std::bind
,例如:
Foo foo;
Bar bar; //I create an instance of an Bar, called bar.
foo.registerCallback(std::bind(&Bar::getStuff, std::ref(bar))); //<--- ERROR!!!!
错误:
error C2562: 'std::_Callable_obj<std::_Bind<true,std::shared_ptr<sf::Sprite>,std::_Pmf_wrap<std::shared_ptr<sf::Sprite> (__thiscall Bar::* )(void)
如果我想使用void方法,没问题。但是我需要使用 getStuff()
方法,它将 return 变成 smart pointer
到 sf::Sprite 东西。
我怎样才能做到这一点?
鉴于您使用的是 c++11,为什么不用 lambda?
foo.registerCallback([&bar]() { bar.getStuff(); });
Bar::getStuff
returns 你试图丢弃的东西。你只能在 discard 表达式和语句中丢弃东西。
一个解决方案
template<class Callable>
auto discard_callable(Callable&& callable)
{ return [=]() { (void) callable(); }; }
你可以这样使用它:
foo.registerCallback(discard_callable(
std::bind(&Bar::getStuff, std::cref(bar))
));
MCVE
#include <functional>
#include <string>
struct Butler
{
std::string say() const { return "Welcome home, Sir."; }
};
template<class Callable>
auto discard_callable(Callable&& callable)
{ return [=]() { (void) callable(); }; }
int main()
{
Butler igor;
std::function<void()> welcome = discard_callable(std::bind(&Butler::say, std::ref(igor))); // error without discard
welcome();
}