Foro de elhacker.net

Programación => Programación C/C++ => Mensaje iniciado por: Drewermerc en 1 Mayo 2014, 03:42 am



Título: dudas sobre memoria dinamica.
Publicado por: Drewermerc en 1 Mayo 2014, 03:42 am

hola a todos.

bueno tengo unas dudas bueno pues yo no sabia que que realloc se podia usar solo y bueno queria saber si ese metodo es igual de efectivo que usar malloc y realloc juntos.

Código
  1.    #include <stdio.h>
  2.    #include <stdlib.h>
  3.  
  4.    int main(){
  5.    int *lista= NULL, num, i;
  6.  
  7.    do
  8.    {
  9.        i++;
  10.        lista =realloc(lista,(i)*sizeof(int));
  11.        printf("\nElemento ");
  12.        scanf ("%d", &*(lista+i));
  13.        printf("%d\n", lista);
  14.        puts("presiona uno para continuar 0 para salir");
  15.        scanf("%d", &num);
  16.     } while (num == 1);
  17.  
  18.        free(lista);
  19.        return 0;
  20.    }
  21.  
y tambien queria saber por que si guardo datos usando scanf al imprimir los valores me resultados erroneos asi.(aclaro esto es solo cuando se usa realloc solo.)

Código
  1. Elemento 5
  2. 154512
  3. presiona uno para continuar 0 para salir
  4.  


veo que la mayoria usa

Código
  1.    //aceder a los datos
  2.        *(lista+i-1) = 5;
  3.    //guardar datos con scanf
  4.        &*(lista)
  5.  


este tipo para acceder a datos de la memoria o guardar datos en ella yo por regular uso mas este metodo.

Código
  1.    lista[i+1];
  2.    &lista[i];
  3.  

que funciona igual, nose si algun metodo es es el correcto o los dos son corecto y es como cada quien se acomode a programar.
tambien queria saber cual es la diferencia entre esto:


Código
  1.    //si en un programa pongo esto da error al llegar a los 6 registros
  2.    realloc(lista,i+1*sizeof(int));
  3.    //pero si lo pongo asi ya no tengo el error
  4.    realloc(lista,(i+1)*sizeof(int));
  5.  
  6.    //codigo completo
  7.  
  8.        #include <stdio.h>
  9.        #include <stdlib.h>
  10.  
  11.        main()
  12.        {
  13.        int *lista,i=0,r;
  14.        puts("Lista enlazada");
  15.  
  16.        lista=(int *) malloc(sizeof(int));
  17.  
  18.        printf("\nElemento %d de la lista enlazada y preciona 1 para agrgar otro elmento",i+1);
  19.        scanf("%d",&*(lista));
  20.                scanf("%d",&r);
  21.                    while(r==1)
  22.                    {
  23.                        i++;
  24.                        realloc(lista,i+1*sizeof(int));
  25.                        scanf("%d",&*(lista+i));
  26.                        puts("Desea agregar otro elemento");
  27.                        scanf("%d",&r);
  28.  
  29.                    }
  30.  
  31.            for(int x=0;x<i+1;x++)
  32.            {
  33.            printf("%d ",lista[x]);
  34.  
  35.            }
  36.  
  37.            free(lista);
  38.        }
  39.  
  40.  


la verdad yo pense que la memoria dinamica no tenia mcuho uso pero ahora veo que te ayuda a manejar mucho mejor la memoria.
con lo que me surge otra duda si se puede trabar la memoria dinamica y manejar como matrizes, arrays unidimencionales etc. entonces cual seriamas conveniente usar memoria dinamica o las otras opciones o depende del programa que se desallorre.
bueno espero que me puedan ayudar.
saludos a todo.


Título: Re: dudas sobre memoria dinamica.
Publicado por: rir3760 en 1 Mayo 2014, 04:24 am
yo no sabia que que realloc se podia usar solo y bueno queria saber si ese metodo es igual de efectivo que usar malloc y realloc juntos.
Una llamada a realloc con su primer argumento igual a NULL tiene el mismo efecto que llamar a malloc:
Código
  1. char *p;
  2.  
  3. p = realloc(NULL, 100); /* Equivalente a "p = malloc(100);" */

tambien queria saber por que si guardo datos usando scanf al imprimir los valores me resultados erroneos asi.(aclaro esto es solo cuando se usa realloc solo.)
Código
  1. Elemento 5
  2. 154512
  3. presiona uno para continuar 0 para salir
Porque estas imprimiendo la dirección del bloque, si se trata de eso debes utilizar el especificador "%p" y convertir explícitamente la dirección al tipo "void *":
Código
  1. printf("%p\n", (void *) lista);

O si se trata de imprimir los valores almacenados en el bloque debes utilizar un bucle, por ejemplo:
Código
  1. {
  2.   int j;
  3.  
  4.   for (j = 0; j < i; j++)
  5.      printf("%d\n", lista[j]);
  6. }

veo que la mayoria usa
Código
  1. //aceder a los datos
  2. *(lista+i-1) = 5;
  3. //guardar datos con scanf
  4. &*(lista)
No tiene caso utilizar "&*(lista)" ya que el efecto de los operadores se cancela, en otras palabras en lugar de "&*(lista)" basta con utilizar "lista".

Código
  1. //si en un programa pongo esto da error al llegar a los 6 registros
  2. realloc(lista,i+1*sizeof(int));
No funciona porque el operador "*" tiene mayor prioridad que "+" y por ello la expresión se evalúa asi:
Código:
i + (1 * sizeof(int))

cual seriamas conveniente usar memoria dinamica o las otras opciones o depende del programa que se desallorre.
Depende del programa.

Un saludo


Título: Re: dudas sobre memoria dinamica.
Publicado por: Drewermerc en 1 Mayo 2014, 16:18 pm
hola rir3760.
bueno muchas gracias por contestar, ahora si ya me quedo mas claro todo.  :D