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.

¿Fue útil?

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 ().

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top