recallocarray()
Allocate or reallocate a block of memory occupied by an array, and ensure that any newly allocated or released memory is cleared
Synopsis:
#include <stdlib.h>
void* recallocarray( void *ptr,
size_t oldnmemb,
size_t nmemb,
size_t size );
Arguments:
- ptr
- A pointer to the block of memory occupied by the array to be reallocated. This can be NULL if you're allocating and not reallocating the memory; see below for details.
- oldnmemb
- The number of elements in the old array.
- nmemb
- The number of elements in the new array.
- size
- The size, in bytes, of one element of the old/new array. (The element sizes for the old and new array should be the same, as defined by size.)
Library:
libc
Use the -l c option to qcc to link against this library. This library is usually included automatically.
Description:
The recallocarray() function allocates or reallocates the block of memory occupied by an array specified by ptr based on the rules listed below. Also, it checks the "old size" (oldnmemb*size) and the "new size" (nmemb*size) for overflow. Unlike reallocarray(), it also ensures that newly allocated memory is cleared and that memory that is released, when shrinking or reallocation occurs, is cleared.
- If the total "new size" is zero (which means size and/or nmemb is 0), the function returns a non-NULL pointer that's valid only to a corresponding call to free(), realloc(), reallocarray() or recallocarray(). Don't assume that this pointer points to any valid memory.
- If the total "new size" is not zero (which means size and nmemb are not 0) and ptr is NULL, the function ignores oldnmemb and allocates a new block of cleared memory of size nmemb * size (which is checked for overflow).
- Otherwise, when ptr is non-NULL and the total "new size" is
not zero (which means size and nmemb are not 0), the
given size of the old array (oldnmemb * size ) must
be the size of the earlier allocation that returned ptr (otherwise the
behavior is undefined). In this case, recallocarray() reallocates space
for an array with nmemb elements of size bytes each
by:
- shrinking the size of the allocated memory block ptr when size times nmemb is smaller than the current size of ptr
- extending the allocated size of the memory block ptr if there is a large enough block of unallocated memory immediately following ptr
- allocating a new block with the appropriate size (size * nmemb), and copying the contents of ptr to this new block
The recallocarray() function allocates memory from the heap. Use free() to free the block of memory.
The function returns NULL when the memory pointed to by ptr can't be reallocated. In this case, the memory isn't freed, so be careful to maintain a pointer to the old memory block so you can free it later.
In the following example, buffer is set to NULL if the function fails, and won't point to the old memory block. If buffer is your only pointer to the memory block, then you have lost access to this memory.
buffer = recallocarray( buffer, 80, 100, sizeof(int) );
Returns:
A pointer to the start of the allocated memory, or NULL if an error occurred (errno is set).
Errors:
- ENOMEM
- Not enough memory.
Examples:
#include <stdlib.h>
int main( void )
{
char* buffer;
char* new_buffer;
buffer = malloc( 80*sizeof(int) );
if ( buffer == NULL ) {
return EXIT_FAILURE;
}
new_buffer = recallocarray( buffer, 80, 100, sizeof(int) );
if( new_buffer == NULL ) {
/* Couldn't allocate a larger buffer.
Remember that buffer stills point to
allocated memory -- don't leak it! */
free(buffer);
return EXIT_FAILURE;
} else {
buffer = new_buffer;
}
return EXIT_SUCCESS;
}
Environment variables:
See the entry for mallopt().
Classification:
Safety: | |
---|---|
Cancellation point | No |
Signal handler | No |
Thread | Yes |