_aligned_recalloc_dbg
_aligned_malloc または変更し_aligned_offset_malloc で割り当てられたメモリを 0 に初期化されたメモリ ブロックのサイズ (デバッグ バージョンだけ)。
void * _aligned_recalloc_dbg(
void * memblock,
size_t num,
size_t size,
size_t alignment,
const char *filename,
int linenumber
);
パラメーター
[入力] memblock
現在のメモリ ブロックのポインター。[入力] num
要素の数。[入力] size
各要素のサイズ (バイト単位)。[入力] alignment
2. の整数乗する必要がある配置の値。[入力] filename
ソース ファイルの名前へのポインター要求された割り当て操作または NULL。[入力] linenumber
割り当ての操作が要求または NULL のソース ファイルの行番号。
戻り値
_aligned_recalloc_dbg が再割り当てされる場合 (移動) されるメモリ ブロックの void ポインターを返します。戻り値はバッファーの引数が NULL であるかまたは特定のサイズにブロックを配置できる使用可能なメモリがであるサイズがゼロ NULL 必要です。最初のケースでは元のブロックが解放されます。2 回目には元のブロックは変更されません。適切にどの型のオブジェクトを格納するために配置されることが保証されるストレージ領域の戻り値へのポインター。null 以外の型へのポインターを取得するには戻り値の型キャストを使用してください。
またメモリの再割り当てしブロックの配置を変更するとエラーになります。
解説
_aligned_recalloc_dbg は _aligned_recalloc の関数のデバッグ バージョンです。_DEBUG を定義しない場合_aligned_recalloc_dbg を呼び出すたびに_aligned_recalloc の呼び出しに減少します。_aligned_recalloc と _aligned_recalloc_dbg はベース ヒープ メモリ ブロックを再割り当てしますが_aligned_recalloc_dbg は一部のデバッグ機能が格納されます : 調べ割り当て要求の原点を確認するために特定の割り当て型を追跡するブロック型パラメーターと filename と linenumber 情報のテスト対象ブロックのユーザー領域の前後に確保されるバッファー。
_aligned_recalloc_dbg割り当てられたメモリ ブロックのサイズは元により大きいか小さいかはであると思われる要求されたサイズ numsize(*) よりもより多くのスペースを指定されたメモリ ブロックを再割り当てします。デバッグ ヒープ マネージャーによって追加空間がデバッグ メモリ ブロックをリンクするとアプリケーションのデバッグのヘッダー情報とバッファーをオーバーライドするために使用されます。割り当ては元のメモリ ブロックをヒープ内の別の場所に移動するとメモリ ブロックのサイズを変更することになる場合があります。ブロックのユーザー領域は 0xCD 値を格納しておりオーバーライドにバッファーを 0xFD が格納されます。
_aligned_recalloc_dbg は ENOMEM にメモリ割り当てに失敗した場合 errno を設定します ; EINVAL は必要なメモリ量 (前記のオーバーヘッドを含む) _HEAP_MAXREQ を超えるとが返されます。この変更およびそのほかのエラー コードについてはerrno、_doserrno、_sys_errlist、および _sys_nerr を参照してください。
また**_aligned_recalloc_dbg** はパラメーターを検証します。alignment が 2 の累乗でない場合この関数は パラメーターの検証 に説明されているように無効なパラメーター ハンドラーを呼び出します。実行の継続が許可された場合、この関数は NULL を返し、errno を EINVAL に設定します。
デバッグ バージョンのベース ヒープに対するメモリ ブロックの割り当て、初期化、管理方法の詳細については、「メモリ管理とデバッグ ヒープ」を参照してください。標準のヒープ関数とアプリケーションのデバッグ ビルドのデバッグ バージョンとの違いについてはデバッグ バージョンを使用して基本バージョン を参照してください。
必要条件
ルーチン |
必須ヘッダー |
---|---|
_aligned_recalloc_dbg |
<crtdbg.h> |
互換性の詳細については、「C ランタイム ライブラリ」の「互換性」を参照してください。
ライブラリ
C ランタイム ライブラリのデバッグ バージョンのみ。
同等の .NET Framework 関数
該当なし標準 C 関数を呼び出すには、PInvoke を使用します。詳細については、「プラットフォーム呼び出しの例」を参照してください。