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; }