_aligned_realloc
更新 : 2007 年 11 月
_aligned_malloc または _aligned_offset_malloc で割り当てたメモリ ブロックのサイズを変更します。
void * _aligned_realloc(
void *memblock,
size_t size,
size_t alignment
);
パラメータ
[入力] memblock
現在のメモリ ブロック ポインタ。[入力] size
割り当てようとするメモリのサイズ。[入力] alignment
配置の値。2 の累乗値を指定する必要があります。
戻り値
再割り当て (および移動) されたメモリ ブロックへの _aligned_realloc ポインタを返します。サイズに 0 を指定し、バッファ引数を NULL 以外にした場合、またはメモリ不足のためブロックを指定されたサイズに拡張できない場合、戻り値は NULL になります。前者の場合は元のブロックを解放しますが、後者の場合は元のブロックを変更しません。戻り値が指すメモリ領域は、どの型のオブジェクトを格納する場合でも、適切にアライメントされます。void 以外の型へのポインタを得るには、戻り値をキャストします。
メモリの再割り当てを実行して、ブロックのアラインメントを変更すると、エラーになります。
解説
_aligned_realloc は malloc に基づいています。_aligned_offset_malloc の使用方法の詳細については、「malloc」を参照してください。
Visual C++ 2005 では、メモリ割り当てが失敗するか、または要求されたメモリ量が _HEAP_MAXREQ を超える場合、この関数は errno を ENOMEM に設定します。errno の詳細については、「errno、_doserrno、_sys_errlist、および _sys_nerr」を参照してください。_aligned_realloc は、パラメータを検証します。alignment が 2 の累乗ではない場合、「パラメータの検証」に説明されているように、この関数は無効なパラメータ ハンドラを呼び出します。実行の継続が許可された場合、この関数は NULL を返し、errno を EINVAL に設定します。
必要条件
ルーチン |
必須ヘッダー |
---|---|
_aligned_realloc |
<malloc.h> |
使用例
詳細については、「_aligned_malloc」を参照してください。