Compartilhar via


IMalloc::Realloc (Compact 2013)

3/26/2014

This method changes the size of a previously allocated memory block.

Syntax

void* Realloc(
  void* pv, 
  ULONG cb 
);

Parameters

  • pv
    [in] Pointer to the memory block to be reallocated. The pointer can have a NULL value, as discussed in the Remarks section below.
  • cb
    [in] Size, in bytes, of the memory block to be reallocated. It can be zero, as discussed in the Remarks section below.

Return Value

If successful, IMalloc::Realloc returns a pointer to the allocated memory block.

If insufficient memory is available, IMalloc::Realloc returns NULL, or cb is zero and pv is not NULL.

Remarks

IMalloc::Realloc reallocates a block of memory but does guarantee that the contents of the returned memory block are initialized. Therefore, the caller is responsible for initializing it in code, subsequent to the reallocation.

The allocated block may be larger than cb bytes because of the space required for alignment and for maintenance information.

The pv argument points to the beginning of the memory block. If pv is NULL, IMalloc::Realloc allocates a new memory block in the same way that the IMalloc::Alloc method does. If pv is not NULL, it should be a pointer returned by a prior call to IMalloc::Alloc.

The cb argument specifies the size, in bytes, of the new block. The contents of the block are unchanged up to the shorter of the new and old sizes, although the new block can be in a different location.

Because the new block can be in a different memory location, the pointer returned by IMalloc::Realloc is not guaranteed to be the pointer passed through the pv argument. If pv is not NULL and cb is zero, the memory pointed to by pv is freed.

IMalloc::Realloc returns a void pointer to the reallocated (and possibly moved) memory block.

The return value is NULL if the size is zero and the buffer argument is not NULL, or if there is not enough memory available to expand the block to the given size. In the first case, the original block is freed; in the second, the original block is unchanged.

The storage space pointed to by the return value is guaranteed to be suitably aligned for storage of any type of object. To get a pointer to a type other than void, use a type cast on the return value.

To determine whether the platform supports this interface, see Determining Supported COM APIs.

Requirements

Header

objidl.h,
objidl.idl

Library

ole32.lib

See Also

Reference

IMalloc
IMalloc::Alloc
IMalloc::Free