El uso de impulso :: unirse salida como un subíndice de matriz
Pregunta
¿Cómo llego a impulsar :: unen para trabajar con subíndices de matriz? Aquí es lo que estoy tratando de lograr. Por favor consejo.
[servenail: C ++ Progs] $ g ++ -v
La lectura de las especificaciones de /usr/lib/gcc/i386-redhat-linux/3.4.6/specs
Configurado con: ../configure --prefix = / usr --mandir = / usr / share / man --infodir = / usr / share / info --enable-shared --enable-threads = posix --disable-comprobación --with-zlib-sistema --enable -__ cxa_atexit --disable-libunwind-excepciones --enable-java-AWT = GTK --host = i386- RedHat Linux
modelo de hilo: POSIX
gcc versión 3.4.6 20060404 (Red Hat 3.4.6-3)
[servenail: C ++ Progs] $ cat t-array_bind.cpp
#include <map>
#include <string>
#include <algorithm>
#include <boost/lambda/lambda.hpp>
#include <boost/lambda/bind.hpp>
#include <iostream>
using namespace std;
using namespace boost;
using namespace boost::lambda;
class X
{
public:
X(int x0) : m_x(x0)
{
}
void f()
{
cout << "Inside function f(): object state = " << m_x << "\n";
}
private:
int m_x;
};
int main()
{
X x1(10);
X x2(20);
X* array[2] = {&x1, &x2};
map<int,int> m;
m.insert(make_pair(1, 0));
m.insert(make_pair(2, 1));
for_each(m.begin(),
m.end(),
array[bind(&map<int,int>::value_type::second, _1)]->f());
}
[servenail: C ++ Progs] $ g ++ -o t-array_bind t-array_bind.cpp t-array_bind.cpp: En función `int main () ': t-array_bind.cpp: 40: error: no puede competir con 'operador []' en
'Array [boost :: lambda :: bind (const Arg1 y, const Arg2 y) [con Arg1 = int std :: :: * par, Arg2 = boost :: lambda :: lambda_functor>] (((const boost :: lambda :: lambda_functor> &) (+ boost :: lambda :::: _ 1)))] '
Muchas gracias.
Solución
Como se ha explicado Charles, boost :: bind devuelve un objeto de función y no un entero. El objeto de función será evaluado para cada miembro. Una pequeña estructura ayudante va a resolver el problema:
struct get_nth {
template<class T, size_t N>
T& operator()( T (&a)[N], int nIndex ) const {
assert(0<=nIndex && nIndex<N);
return a[nIndex];
}
}
for_each(m.begin(),
m.end(),
boost::bind(
&X::f,
boost::bind(
get_nth(),
array,
bind(&map<int,int>::value_type::second, _1)
)
));
Edit: He cambiado el funtor para devolver el enésimo elemento de la matriz.
Otros consejos
La razón por la que su código no compila es debido a que el valor de retorno de boost::bind
es no un tipo entero que puede ser utilizado como un subíndice de matriz. Más bien, boost::bind
devuelve una función de objeto definido por la implementación de un tipo no especificado, que puede ser llamado usando el operador ()
.