AYUDA: problema con funcion miembro de clase

Iniciado por t4r0x, 12 Diciembre 2014, 02:10 AM

0 Miembros y 2 Visitantes están viendo este tema.

t4r0x

buenas a todos veran tengo problemas al intentar compilar el codigo de abajo, lo que quiero hacer en obtener el puntero de un funcion miembro de una clase, guardarlo en la estructura y luego llamar a esa funcion... pero me esta dando problemas al compilar y no comprendo porque, probe con el puntero this pero nada, talvez usando static pero no quiero hacer todas las funciones de la clase estaticas porque son muchas y prefiero no usar static.

podria alguien decirme porque no funciona y alguna solucion? gracias

Código (cpp) [Seleccionar]

int  main()
{
    MiClase c1;
    estructura es;

    c1.funcion2(&es);

    return 0;
}



prueba.h
Código (cpp) [Seleccionar]
class MiClase;

typedef int(MiClase::*puntero1)(int);

typedef struct _estructura
{
   puntero1 p1;
   int n1;
   int n2;
   int n3;
   int n4;

}estructura;

class MiClase
{
public:
   int funcion1(int valor);
   void funcion2(estructura* datos);
   int funcion3(estructura* datos);

};


prueba.cpp
Código (cpp) [Seleccionar]
#include "prueba.h"


int MiClase::funcion1(int valor)
{
   return valor + 40;
}

VOID MiClase::funcion2(estructura* datos)
{
   datos->p1 = funcion1;
   datos->n1 = 10;
   datos->n2 = 20;
   datos->n3 = 30;
   datos->n4 = 40;
}

int MiClase::funcion3(estructura* datos)
{
   datos->p1(10);
}

eferion

A ver, los punteros a funciones miembro no funcionan exactamente igual que los punteros a funciones que, imagino, estás acostumbrado a usar.

Código (cpp) [Seleccionar]

class POO
{
  public:
    int funcion( );
}


Si yo creo 20 instancias de la clase que he declarado encima de esta línea, en el código no voy a encontrar 20 copias de "funcion". Únicamente habrá una y será compartida por todas las instancias de "POO". Esto quiere decir que, aunque tu veas que la firma de la función es, símplemente, "int funcion( );", internamente esta función ha de recibir un puntero que apunte a la instancia de "POO" sobre la que tiene que trabajar.

El ejemplo que tu has puesto te podría servir, con algún retoque, para referenciar funciones miembro estáticas, pero no te sirve para funciones miembro dependientes de la instancia. Si quieres acceder a una función no estática necesitas facilitar una instancia de FOO válida.

Lo que pretendes hacer tiene mejores soluciones:

* Guardas simplemente un puntero a "MiClase" en la estructura.
* Haces que "funcion1" sea estática, dado que no accede a elementos no estáticos de la instancia "no vas a tener problemas
* Te replanteas el diseño. Esta opción es la recomendada salvo que estés haciendo una práctica. Este tipo de códigos complican muchísimo el mantenimiento de una aplicación.

t4r0x

#2
La verdad es que estoy pasando una aplicacion entera a codigo C++ e implementarlo en clases entonces el codigo fuente de la aplicacion tiene mas 20,000 lineas de codigo entre todos los archivos .cpp y .h y se me haria complicado rehacer la aplicacion, y por eso simplemente no quiero tocar nada del codigo e implementar las funciones dentro varias clases, tengo casi todo el codigo listo solo me falta esa parte en donde no puedo encontrar una solucion :/

eferion

Migrar aplicaciones siempre es complicado y, por experiencia, considero un error intentar que la migración reproduzca de forma totalmente fiel la arquitectura anterior.

El problema que se suele producir es que el código acaba siendo poco amigable, ya que cada lenguaje tiene sus propias características y cosas que en un lenguaje se hacen de una forma, en otro deben hacerse de forma totalmente diferente. Esto hace que aparezcan estructuras raras y poco claras que acaban dando problemas.

Si el código va a acabar siendo el mismo entonces no vas a obtener ninguna ventaja por la migración.

Mi consejo es que las partes feas como estas reciban un repaso y se refactoricen como es debido. Se que al final es como todo, hay dinero de por medio que limita el alcance de todo proyecto, pero una arquitectura bien hecha reduce muchísimo el mantenimiento futuro... es elegir entre pagar un poco más hoy o un mucho más mañana.

t4r0x

No perdon quiza escribi mal pero la aplicacion esta en C/C++ pero no es implementada en clases asi que lo que estoy haciendo es simplementa creando clases para cada cpp o para cada grupo de funciones que se relacionen, la verdad es que en el codigo original no veo que sea raro ya que se inicializa esa estructura con algunos valores y punteros a funciones para luego usar esos punteros dentro de otras funciones... y si declaro a funcion como estatica en la clase el compilador me dice que las demas funciones deben ser estaticas tambien y el resto de funciones llaman a otras y asi, al final el compilador me muestra cientos de errores... asi que simplemente queria saber como arreglar eso, la verdad me parece extraño no poder compilar eso... ya uqe tiene algo sentido hacer lo que estoy haciendo... creo :P

eferion

Código (cpp) [Seleccionar]
class FOO
{
public:

  void func1( )
  {std::cout << "func1" << std::endl;

  void func2( )
  { func3( ); }

  void func3( )
  { std::cout << "func3" << std::endl; }
};


En este ejemplo, tanto func1 como func3 pueden pasar a ser estáticas sin ningún problema, ya que no arrastran dependencias a miembros no estáticos.

Sin embargo, para pasar "func2" a estática sería necesario hacer "func3" también estática, ya que func2 depende de "func3" y una función estática no puede acceder directamente a los miembros no estáticos de una clase.

t4r0x

pero lo que pasa es que ese es solo un ejemplo lo mas sencillo que pude para poder plantear la pregunta :P ya que en el codigo que quiero resolver hay muchas funciones y variables que se llaman entre si... ademas no puedo definir la funcion dentro de la definicion de la clase ya que hay algunas funciones que necesitan punteros a estructuras definidas que estas mismas necesitan typedef de punteros a otras funciones y pobre con haciendo forwarding de algunas estructuras y clases pero el lio se hace bastante extenso y al final no me resuelve nada.

Y si como le dije no quiero definir las funciones como estaticas porque me resultan cientos de errores.

eferion

ok ok, yo el planteamiento que te he dicho parte del desconocimiento más absoluto del código con el que estás trabajando. Obviamente sin tener código es difícil dar soluciones concretas.

En cualquier caso, que te sea breve :)

Un saludo.

t4r0x

alguien sabe porqué ese codigo de arriba no compila y darme una solucion a ese codigo?

Eternal Idol

La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste.
Juan Domingo Perón