Namespaces
Variants
Views
Actions

realloc

From cppreference.com
< c‎ | memory
Revision as of 03:52, 14 May 2013 by Cubbi (Talk | contribs)

Defined in header <stdlib.h>
void *realloc( void *ptr, size_t new_size );

Reallocates the given area of memory. It must be previously allocated by Template:rlpf, Template:rlpf or realloc() and not yet freed with Template:rlpf, otherwise, the results are undefined.

The reallocation is done by either:

a) expanding or contracting the existing area pointed to by ptr, if possible. The contents of the area remain unchanged up to the lesser of the new and old sizes. If the area is expanded, the contents of the new part of the array are undefined.
b) allocating a new memory block of size new_size bytes, copying memory area with size equal the lesser of the new and the old sizes, and freeing the old block.

If there is not enough memory, the old memory block is not freed and null-pointer is returned.

Contents

Parameters

ptr - pointer to the memory area to be reallocated
new_size - new size of the array

Return value

Pointer to the beginning of newly allocated memory or NULL if error has occurred. The pointer must be deallocated with Template:rlpf.

Example

See also

C++ documentation for realloc