2011-01-06 9 views
0

Ich möchte ein boost::function verwenden und es an eine Funktion übergeben, die als Callback fungiert. Ich habe Probleme, die Member-Funktion zuzuweisen.boost :: function Zuordnung zu Member-Funktion

Die Funktion, an die ich es übergeben möchte, ist eine statische Funktion (wie es in einem anderen Thread aufgerufen wird).

boost::function<std::string (ResolverReply& reply)> call_back = std::bind1st(std::mem_fun(&ResolverCommunicator::reply_call_back), *this); 

Dies ist in der ResolverCommunicator Klasse, aber mein Compiler beschwert sich über:

_Right: reference to reference is illegal 

c:\Program Files\Microsoft Visual Studio .NET 2003\Vc7\include\functional(278): error C2535: 'std::binder1st<_Fn2>::result_type std::binder1st<_Fn2>::operator()(std::binder1st<_Fn2>::argument_type &) const' : member function already defined or declared 
     with 
     [ 
      _Fn2=std::mem_fun1_t<std::string,ResolverCommunicator,ResolverReply &> 
     ] 
     c:\Program Files\Microsoft Visual Studio .NET 2003\Vc7\include\functional(272) : see declaration of 'std::binder1st<_Fn2>::operator`()'' 
     with 
     [ 
      _Fn2=std::mem_fun1_t<std::string,ResolverCommunicator,ResolverReply &> 
     ] 

ich dann call_back auf meine statische Funktion nur auf der Durch, die auf einem anderen Thread aufgerufen wird.

Weiß jemand, was falsch ist?

EDIT:

ich getan habe, wie die Antwort sagt, aber jetzt bekomme ich diesen Fehler:

error C2665: 'boost::bind' : none of the 3 overloads can convert parameter 2 from type 'ResolverCommunicator' 
     c:\Program Files\boost\boost_1_44\boost\bind\bind.hpp(1480): could be 'boost::_bi::bind_t<R,F,L> boost::bind<std::string(__thiscall ResolverCommunicator::*)(ResolverReply &),ResolverCommunicator,boost::arg<I>>(F,A1,A2)' 
     with 
     [ 
      R=boost::_bi::unspecified, 
      F=std::string (__thiscall ResolverCommunicator::*)(ResolverReply &), 
      L=boost::_bi::list2<boost::_bi::list_av_2<ResolverCommunicator,boost::arg<1>>::B1,boost::_bi::list_av_2<ResolverCommunicator,boost::arg<1>>::B2>, 
      I=1, 
      A1=ResolverCommunicator, 
      A2=boost::arg<1> 
     ] 
     c:\Program Files\boost\boost_1_44\boost\bind\bind_mf_cc.hpp(43): or  'boost::_bi::bind_t<R,F,L> boost::bind<std::string,ResolverCommunicator,ResolverReply&,ResolverCommunicator,boost::arg<I>>(R (__thiscall ResolverCommunicator::*)(B1),A1,A2)' 
     with 
     [ 
      R=std::string, 
      F=boost::_mfi::mf1<std::string,ResolverCommunicator,ResolverReply &>, 
      L=boost::_bi::list2<boost::_bi::list_av_2<ResolverCommunicator,boost::arg<1>>::B1,boost::_bi::list_av_2<ResolverCommunicator,boost::arg<1>>::B2>, 
      I=1, 
      B1=ResolverReply &, 
      A1=ResolverCommunicator, 
      A2=boost::arg<1> 
     ] 
     c:\Program Files\boost\boost_1_44\boost\bind\bind_mf_cc.hpp(54): or  'boost::_bi::bind_t<R,F,L> boost::bind<std::string,ResolverCommunicator,ResolverReply&,ResolverCommunicator,boost::arg<I>>(R (__thiscall ResolverCommunicator::*)(B1) const,A1,A2)' 
     with 
     [ 
      R=std::string, 
      F=boost::_mfi::cmf1<std::string,ResolverCommunicator,ResolverReply &>, 
      L=boost::_bi::list2<boost::_bi::list_av_2<ResolverCommunicator,boost::arg<1>>::B1,boost::_bi::list_av_2<ResolverCommunicator,boost::arg<1>>::B2>, 
      I=1, 
      B1=ResolverReply &, 
      A1=ResolverCommunicator, 
      A2=boost::arg<1> 
     ] 
     while trying to match the argument list '(std::string (__thiscall 
ResolverCommunicator::*)(ResolverReply &), ResolverCommunicator, boost::arg<I>)' 
     with 
     [ 
      I=1 
     ] 
+0

std :: string reply_call_back (ResolverReply & antwort); –

Antwort

4

Es ist eine bekannte Einschränkung der Standard-Bindemittel, die sie handhaben keine Funktionen, die sie nehmen Parameter als Referenz. Sie sollten in Betracht ziehen, boost::bind zu verwenden:

boost::function<std::string (ResolverReply& reply)> call_back = 
    boost::bind(&ResolverCommunicator::reply_call_back, this, _1); 
+0

Sie können dies oder * this einfügen, und boost :: bind ist clever genug, um beides zu lösen. Es kann sogar shared_ptr als 2. Parameter auflösen. Für das OP ist das _1 ein Platzhalter für den Parameter der Funktion (die ResolverReply &) – CashCow

+0

@CashCow Sie haben Recht, und die Verwendung von '* this' ist sogar eine schlechte Idee, wenn nicht in einem' boost :: ref() ': Antwort bearbeitet – icecrime