将回调绑定到模板化对象

时间:2018-01-30 17:05:40

标签: c++ templates boost-bind

我有一个带有回调的模板类,存储为std::function

typedef std::function<void()> func_t;

template<typename T>
struct A
{
   T someMember;
   func_t callback;
};

这个回调是由某种机制(boost :: asio)调用的,我想传递参数,所以我绑定它们:

例如:

void a_callback( int v )
{
    std::cout << "value=" << v << "\n";
}

并将其存储在对象中。

enum EN { ONE, TWO };

int main()
{
    A<EN> a;

    a.callback = boost::bind( a_callback, 42); // ok
    a.callback(); // ok
}

到目前为止,一切都很好。

但是现在我想将对象本身传递给回调函数,以便它可以对其进行操作。回调变得模板化,因为对象类是:

template<typename T>
void b_callback( A<T>& b, int v )
{
    std::cout << "value=" << v << "\n";
}

但是试图绑定它失败了:

int main()
{
    A<EN> a2;  
    a2.callback = boost::bind( b_callback, a2, 42); 
}

Clang说:

error: no matching function for call to 'bind'
    a2.callback = boost::bind( b_callback, a2, 42); // build error
/usr/local/include/boost/bind/bind.hpp:1891:5: note: candidate template ignored: couldn't infer template argument 'R'
    BOOST_BIND(F f, A1 a1, A2 a2)
/usr/local/include/boost/bind/bind.hpp:1868:20: note: expanded from macro 'BOOST_BIND'
#define BOOST_BIND bind

Full code here (coliru)

我做错了什么?我该如何管理?

1 个答案:

答案 0 :(得分:1)

您需要使用具体类型EN实例化一个函数模板:

a2.callback = boost::bind(&b_callback<EN>, a2, 42);

因为b_callback是函数模板,而不是函数。

EXAMPLE