stdlib.h


Función realloc ANSI C

void *realloc(void *ptr, size_t tamanyo);

Cambia el tamaño del objeto apuntado por ptr al tamaño especificado por tamanyo. El contenido del objeto no cambiará hasta el menor de los tamaños nuevo y viejo. Si el tamaño nuevo es mayor, el valor de la porción nuevamente adjudicada del objesto es indeterminado. Si ptr es un puntero nulo, la función realloc se comporta a igual que la función malloc para el tamaño especificado. De lo contrario, si ptr no es igual a un puntero previamente retornado por la función calloc, malloc, o realloc, o si el espacio ha sido desadjudicado por una llamada a la función free, o realloc, el comportamiento no está definido. Si el espacio no puede ser desadjudicado, el objeto apuntado por ptr no varía. Si tamanyo es cero y ptr no es nulo, el objeto al que apunta es liberado.

Valor de retorno:

La función realloc retorna o bien un puntero nulo o bien un puntero posiblemente al espacio adjudicado mudado.

Ejemplo:

#include <stdio.h>
#include <stdlib.h>

int main( void )
{
   int *numPtr, i;
   size_t tamanyo=0;

   printf( "Introduzca el tamaño de la lista: " );
   scanf( "%d", &tamanyo );

   puts( "Adjudicamos espacio a la lista." );
   numPtr = (int *)malloc( tamanyo*sizeof(int) );

   for( i=0; i<tamanyo-1; i++ )
      printf( "%d, ", numPtr[i] = rand() % 100 + 1 );
   printf( "%d\n", numPtr[i] = rand() % 100 + 1 );

   numPtr = (int *)realloc( numPtr, tamanyo/=2 );
   printf( "Recortamos la lista a la mitad: %d\n", tamanyo );
   for( i=0; i<tamanyo-1; i++ )
      printf( "%d, ", numPtr[i] );
   printf( "%d\n", numPtr[i] );

   puts( "Liberamos el espacio." );
   free( numPtr );

   return 0;
}