Я подготовил небольшой фрагмент, изолирующий мою проблему здесь.
Вот :
#include <stdio.h>
#include <future>
#include <functional>
class foo
{
public:
foo(int a, int b) : m_a(a), m_b(b) {}
int somefunc(int a, int b) { printf("foo w0w : %d, %d", a == m_a, b == m_b); return 0; }
void meow() {
std::packaged_task<int(int, int)> task( std::bind(&foo::somefunc, this) );
task(10, 12);
return;
}private:
int m_a, m_b;
};int main(void)
{
foo bar(1,2);
return 0;
}
GCC не хочет компилировать это, заявляя:
In file included from c:\mingw\include\c++\4.8.3\thread:39:0,
from xcc.cpp:7:
c:\mingw\include\c++\4.8.3\functional: In instantiation of 'struct std::_Bind_simple<std::reference_wrapper<std::_Bind<std::_Mem_fn<int (foo::*)(int, int)>(foo*)> >(int, int)>':
c:\mingw\include\c++\4.8.3\future:1276:55: required from 'void std::__future_base::_Task_state<_Fn, _Alloc, _Res(_Args ...)>::_M_run(_Args ...) [with _Fn = std::_Bind<std::_Mem_fn<int (foo::*)(int, int)>(foo*)>; _Alloc = std::allocator<int>; _Res = int; _Args = {int, int}]'
xcc.cpp:40:1: required from here
c:\mingw\include\c++\4.8.3\functional:1697:61: error: no type named 'type' in 'class std::result_of<std::reference_wrapper<std::_Bind<std::_Mem_fn<int (foo::*)(int, int)>(foo*)> >(int, int)>'
typedef typename result_of<_Callable(_Args...)>::type result_type;
^
c:\mingw\include\c++\4.8.3\functional:1727:9: error: no type named 'type' in 'class std::result_of<std::reference_wrapper<std::_Bind<std::_Mem_fn<int (foo::*)(int, int)>(foo*)> >(int, int)>'
_M_invoke(_Index_tuple<_Indices...>)
^
Я на грани выгорания, пытаясь заставить эту работу. Сообщение об ошибке компилятора является полной фигней для меня, таким образом, я полностью потерян. Пожалуйста, помогите, как этого добиться.
Не код только для примера, в моем реальном проекте я использую packaged_task с std :: thread (std :: move (task) и т. Д.).
Спасибо!
Вам нужны два заполнителя для аргументов, с которыми вы собираетесь его вызывать:
using namespace std::placeholders;
std::packaged_task<int(int, int)> task(std::bind(&foo::somefunc, this, _1, _2));