que tienen una estructura como esta:Usando bind1st por un método que toma el argumento por referencia
struct A {
void i(int i) {}
void s(string const &s) {}
};
Ahora cuando intento esto:
bind1st(mem_fun(&A::i), &a)(0);
bind1st(mem_fun(&A::s), &a)("");
La primera línea compila bien, pero la segunda genera un error:
c:\program files (x86)\microsoft visual studio 10.0\vc\include\xfunctional(299): error C2535: 'void std::binder1st<_Fn2>::operator()(const std::basic_string<_Elem,_Traits,_Ax> &) const' : member function already defined or declared
with
[
_Fn2=std::mem_fun1_t<void,A,const std::string &>,
_Elem=char,
_Traits=std::char_traits<char>,
_Ax=std::allocator<char>
]
c:\program files (x86)\microsoft visual studio 10.0\vc\include\xfunctional(293) : see declaration of 'std::binder1st<_Fn2>::operator()'
with
[
_Fn2=std::mem_fun1_t<void,A,const std::string &>
]
c:\work\sources\exception\test\exception\main.cpp(33) : see reference to class template instantiation 'std::binder1st<_Fn2>' being compiled
with
[
_Fn2=std::mem_fun1_t<void,A,const std::string &>
]
¿Cuál podría ser el problema? ¿Cómo podría solucionarlo?
Editar:
parece que cualquier argumento de referencia es un problema. Entonces, si cambio el método i
al void i(int &i) {}
, aparece un error similar.
Dado que estamos en el año 2011 y tiene 11 C++ es posible que desee echar un vistazo a C++ '11s std :: bind' o' boost :: bind 'que hace que esas cosas órdenes de magnitud sean más fáciles de manejar. – PlasmaHH
@PlasmaHH: Desafortunadamente, no puedo usar C++ 11 en este proyecto. –
Y también no 'boost :: bind'? – PlasmaHH