If realloc fails and returns NULL is the former buffer free'd or it is kept intact? I didn't found that particular piece of information in the man page and I'm quite unsure what to do. If memory is freed then double-free could be risky. If not then the leakage would occur.
No, it does not. That aspect has often annoyed me since you can't just use:
if ((buff = realloc (buff, newsize)) == NULL)
return;
in your code if you want to free the original on failure. Instead you have to do something like:
if ((newbuff = realloc (buff, newsize)) == NULL) {
free (buff);
return;
}
buff = newbuff;
Of course, I understand the rationale behind keeping the original buffer intact on failure but my use case has popped up enough that I generally code my own functions to handle that case, something like:
// Attempt re-allocation. If fail, free old buffer, return NULL.
static void *reallocFreeOnFail (void *oldbuff, size_t sz) {
void *newbuff = realloc (oldbuff, sz);
if (newbuff == NULL) free (oldbuff);
return newbuff;
}
// Attempt re-allocation. If fail, return original buffer.
// Variable ok is set true/false based on success of re-allocation.
static void *reallocLeaveOnFail (void *oldbuff, size_t sz, int *ok) {
void *newbuff = realloc (oldbuff, sz);
if (newbuff == NULL) {
*ok = 0;
return oldbuff;
}
*ok = 1;
return newbuff;
}
The relevant section in the C11 standard states (my italics):
7.20.3.4 The
realloc
functionIf
ptr
is a null pointer, therealloc
function behaves like themalloc
function for the specified size. Otherwise, ifptr
does not match a pointer earlier returned by thecalloc
,malloc
, orrealloc
function, or if the space has been deallocated by a call to thefree
orrealloc
function, the behavior is undefined. If memory for the new object cannot be allocated, the old object is not deallocated and its value is unchanged.
old
so my check doesn't really buy that much. I'll get rid of it. –
Roussel realloc
and just call free(old)
if sz==0
. This is because there's some degree of disagreement on what realloc
returning 0 can mean. Some people claim it's legal to return 0 (and not set errno
) if the memory was successfully resized to size 0 and the implementation has malloc(0)==NULL
, in which case the subsequent free(old)
would be a dangerous double-free. I would write the function: void *new=0; if (!sz || !(new=realloc(old,sz))) free(old); return new;
–
Chaschase realloc
-to-size-zero you probably need to return malloc(1);
in this case... uhg.. –
Chaschase realloc(ptr, 0)
can fail to free ptr
and should not be used, but realloc(3)
says it is "equivalent to free(ptr)
," which cannot fail because free()
is void
and is unable to indicate failure. –
Vinni
realloc()
returns a pointer to the newly allocated memory, which is suitably aligned for any kind of variable and may be different fromptr
, orNULL
if the request fails. Ifsize
was equal to 0, eitherNULL
or a pointer suitable to be passed tofree()
is returned. Ifrealloc()
fails the original block is left untouched; it is not freed or moved.
No. No change of the former buffer is done if realloc()
failed.
man
realloc(3)
:
realloc()
returns a pointer to the newly allocated memory, which is suitably aligned for any kind of variable and may be different fromptr
, orNULL
if the request fails. If size was equal to 0, eitherNULL
or a pointer suitable to be passed tofree()
is returned. Ifrealloc()
fails the original block is left untouched; it is not freed or moved.
No.It won't. Realloc changes increases/decreases the dynamic memory allocated via malloc or calloc. It will return NULL in case realloc fails while increasing memory but it won't change previously allocated memory. As Realloc computes new memory allocation from the base address of previously allocated memory, it does not perform any operation on the memory
© 2022 - 2024 — McMap. All rights reserved.
NULL
once before callingfree
and again insidefree
) costs more in the common case (where the pointer is notNULL
) and only helps minimally in the rare case (where the pointer isNULL
). I would say it's a net loss. – Chaschase