次の方法で共有


_aligned_offset_realloc_dbg

_aligned_malloc または _aligned_offset_malloc (デバッグ バージョンだけ) で割り当てられたメモリ ブロックのサイズを変更します。

void * _aligned_offset_realloc_dbg(
   void *memblock, 
   size_t size, 
   size_t alignment,
   size_t offset,
   const char *filename,
   int linenumber 
);

パラメーター

  • [入力] memblock
    現在のメモリ ブロックのポインター。

  • [入力] size
    メモリ割り当てのサイズ。

  • [入力] alignment
    2. の整数乗する必要がある配置の値。

  • [入力] offset
    配置を設定するメモリ割り当てのオフセット。

  • [入力] filename
    要求されたソース ファイル名へのポインター aligned_offset_realloc 操作または NULL。

  • [入力] linenumber
    aligned_offset_realloc 操作が要求または空白のソース ファイルの行番号。

戻り値

_aligned_offset_realloc_dbg が再割り当てされる場合 (移動) されるメモリ ブロックの void ポインターを返します。戻り値はバッファーの引数が NULL であるかまたは特定のサイズにブロックを配置できる使用可能なメモリがであるサイズがゼロ NULL 必要です。最初のケースでは元のブロックが解放されます。2 回目には元のブロックは変更されません。適切にどの型のオブジェクトを格納するために配置されることが保証されるストレージ領域の戻り値へのポインター。null 以外の型へのポインターを取得するには戻り値の型キャストを使用してください。

解説

_aligned_offset_realloc_dbg は _aligned_offset_realloc の関数のデバッグ バージョンです。_DEBUG を定義しない場合_aligned_offset_realloc_dbg を呼び出すたびに_aligned_offset_realloc の呼び出しに減少します。aligned_offset_realloc _ と _aligned_offset_realloc_dbg はベース ヒープ メモリ ブロックを再割り当てしますが_aligned_offset_realloc_dbg は一部のデバッグ機能が格納されます : 調べ割り当て要求の原点を確認するために特定の割り当て型を追跡するブロック型パラメーターと filename と linenumber 情報のテスト対象ブロックのユーザー領域の前後に確保されるバッファー。

_aligned_offset_malloc と同様に構造体を _aligned_offset_realloc_dbg 構造内のオフセットに配置します。

_realloc_dbg は要求された newSize よりもより多くのスペースを指定されたメモリ ブロックを再割り当てします。newSize割り当てられたメモリ ブロックのサイズは元により大きいか小さいかである可能性があります。デバッグ ヒープ マネージャーによって追加空間がデバッグ メモリ ブロックをリンクするとアプリケーションのデバッグのヘッダー情報とバッファーをオーバーライドするために使用されます。割り当ては元のメモリ ブロックをヒープ内の別の場所に移動するとメモリ ブロックのサイズを変更することになる場合があります。メモリ ブロックが移動された場合は元のブロックの内容が上書きされます。

メモリ割り当てに失敗したり要求が _HEAP_MAXREQ サイズよりも大きい場合は関数のセット errnoENOMEMこの。errno の詳細については、「errno、_doserrno、_sys_errlist、および _sys_nerr」を参照してください。また_aligned_offset_realloc_dbg はパラメーターを検証します。alignment が 2 の累乗でないかoffset が size 以上でまたはゼロ以外の場合この関数は パラメーターの検証 に説明されているように無効なパラメーター ハンドラーを呼び出します。実行の継続が許可された場合、この関数は NULL を返し、errno を EINVAL に設定します。

デバッグ バージョンのベース ヒープに対するメモリ ブロックの割り当て、初期化、管理方法の詳細については、「メモリ管理とデバッグ ヒープ」を参照してください。割り当てブロックの型についてはそれらがどのように使用されるかについてはデバッグ ヒープ ブロックの型 を参照してください。アプリケーションのデバッグ ビルドの標準とデバッグ バージョンのヒープ関数呼び出しの違いについてはデバッグ バージョンを使用して基本バージョン を参照してください。

必要条件

ルーチン

必須ヘッダー

_aligned_offset_realloc_dbg

<crtdbg.h>

互換性の詳細については、「C ランタイム ライブラリ」の「互換性」を参照してください。

ライブラリ

C ランタイム ライブラリのデバッグ バージョンのみ。

同等の .NET Framework 関数

該当なし標準 C 関数を呼び出すには、PInvoke を使用します。詳細については、「プラットフォーム呼び出しの例」を参照してください。

参照

関連項目

デバッグ ルーチン