realloc
lavori dietro le quinte o meno così:
- se c'è abbastanza spazio libero dietro il blocco corrente per soddisfare la richiesta, di estendere il blocco corrente e restituire un puntatore all'inizio del blocco .
- Altrimenti se c'è un blocco libero abbastanza grande altrove, quindi allocare quel blocco, copiare i dati dal vecchio blocco, liberare il vecchio blocco e restituire un puntatore all'inizio del nuovo blocco
- restituendo
NULL
.
Quindi, è possibile verificare per il mancato testando per NULL
, ma essere consapevoli del fatto che non sovrascrivere il vecchio puntatore troppo presto:
int* p = malloc(x);
/* ... */
p = realloc(p, y); /* WRONG: Old pointer lost if realloc fails: memory leak! */
/* Correct way: */
{
int* temp = realloc(p, y);
if (NULL == temp)
{
/* Handle error; p is still valid */
}
else
{
/* p now possibly points to deallocated memory. Overwrite it with the pointer
to the new block, to start using that */
p = temp;
}
}
fonte
2010-09-10 11:55:50
È questo il 'realloc' funziona per tutte le implementazioni? –
@CoolGuy: Alcune implementazioni potrebbero non (essere in grado di) fare quel primo passo di estendere il blocco corrente, ma altrimenti questo è il comportamento osservabile di 'realloc' per tutte le implementazioni. –