我有一个带有回调的模板类,存储为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
我做错了什么?我该如何管理?
答案 0 :(得分:1)
您需要使用具体类型EN
实例化一个函数模板:
a2.callback = boost::bind(&b_callback<EN>, a2, 42);
因为b_callback
是函数模板,而不是函数。