Friday, 23 August 2019

c++ - std::async call of member function




Consider the following class:



class Foo
{
private:
void bar(const size_t);
public:
void foo();
};



now Foo::foo() should start threads executing bar, so this is how it's implemented:



void Foo:foo()
{
auto handle = std::async(std::launch::async, &Foo::bar, this, 0);
handle.get();
}



This works flawlessly with g++-4.6.3, but not with g++-4.5.2, the error message is




include/c++/4.5.2/functional:180:9: Error: must use ».« or »->« to call pointer-to-member function in »std::declval with _Tp = void (Foo::*)(long unsigned int), typename std::add_rvalue_reference<_Tp>::type = void (Foo::&&)(long unsigned int) (...)«, e.g. »(... -> std::declval with _Tp = void (Foo::*)(long unsigned int), typename std::add_rvalue_reference<_Tp>::type = void (Foo::*&&)(long unsigned int)) (...)«




So obviously the error lies within the old version of g++. It is possible to work around this issue by making the method public and introducing the following helper function:



void barHelp(Foo* foo, const size_t n)

{
foo->bar(n);
}
void Foo:foo()
{
auto handle = std::async(std::launch::async, barHelp, this, 0);
handle.get();
}



However, making a method public isn't the best design decision. Is there another way to work around this issue without changing the compiler and leaving the method private?


Answer



The problem appears to be that it won't play nice with member functions. Perhaps you can std::bind the member function to your object first, before passing it to std::async:



auto func = std::bind(&Foo::bar, this, std::placeholders::_1);
auto handle = std::async(std::launch::async, func, 0);

No comments:

Post a Comment

php - file_get_contents shows unexpected output while reading a file

I want to output an inline jpg image as a base64 encoded string, however when I do this : $contents = file_get_contents($filename); print ...