_heapset

提供: RAD Studio
移動先: 案内検索

alloc.h:インデックス への移動


ヘッダーファイル

malloc.h

カテゴリ

メモリルーチン

プロトタイプ

int _heapset(unsigned int fillvalue);

説明

ヒープ上の空きブロックに定数値を格納します。

_heapset は,_heapchk と同じ方法を使用して,ヒープの一貫性をチェックします。次に,ヒープ上の各空きブロックに fillvalue の最下位バイトにある値を挿入します。この関数は,ヒープに関連する問題を発見するために使用できます。この後で割り当てられるブロックに指定の値が格納されるかどうかは保証されません。

戻り値

次のいずれかの値です。

_HEAPOK

ヒープは破損していません。

_HEAPEMPTY

ヒープが存在しません。

_HEAPBADNODE

破損したヒープブロックが見つかりました。





 #include <windowsx.h>
 #include <malloc.h>
 #include <stdio.h>
 #include <stdlib.h>
 BOOL InitApplication(HINSTANCE hInstance);
 HWND InitInstance(HINSTANCE hInstance, int nCmdShow);
 LRESULT FAR PASCAL _export MainWndProc(HWND hWnd, UINT message,
             WPARAM wParam, LPARAM lParam);
 void ExampleHeapSet(HWND hWnd);
 #pragma argsused
 int PASCAL WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
         LPSTR lpCmdLine, int nCmdShow)
 {
 MSG msg;      // message
   if (!InitApplication(hInstance))  // 共有物を初期化します
    return (FALSE); // 初期化できない場合は終了します
   /* 特定のインスタンスに適用される初期化を実行します */
   if (!(InitInstance(hInstance, nCmdShow)))
    return (FALSE);
   /* WM_QUIT メッセージを受け取るまで,メッセージを取得してディスパッチします。*/
   while (GetMessage(&msg, // メッセージ構造体
    NULL, // メッセージを受け取るウィンドウのハンドル
    NULL, // 調べる必要がある最下位のメッセージ
    NULL))  // 調べる必要がある最上位のメッセージ
   {
   TranslateMessage(&msg); // 仮想キーコードの変換
   DispatchMessage(&msg);  // メッセージをウィンドウにディスパッチします
   }
   return (msg.wParam);  // PostQuitMessage からの値を返します
 }
 BOOL InitApplication(HINSTANCE hInstance)
 {
   WNDCLASS  wc;
   // メインウィンドウを記述するパラメータをウィンドウクラス構造体に
   // 書き込みます
   wc.style = CS_HREDRAW | CS_VREDRAW; // クラススタイル
   wc.lpfnWndProc = (long (FAR PASCAL*)(void *,unsigned int,unsigned int, long ))MainWndProc; // このクラスのウィンドウのメッセージを
                 // 取得する関数
   wc.cbClsExtra = 0;  // クラスの追加データなし
   wc.cbWndExtra = 0;  // ウィンドウの追加データなし
   wc.hInstance = hInstance; // クラスを所有するアプリケーション
   wc.hIcon = LoadIcon(NULL, IDI_APPLICATION);
   wc.hCursor = LoadCursor(NULL, IDC_ARROW);
   wc.hbrBackground = GetStockObject(WHITE_BRUSH);
   wc.lpszMenuName = NULL;  // .RC ファイル内のメニューリソースの名前
   wc.lpszClassName = "Example"; // CreateWindow の呼び出しで使用される名前
   /* ウィンドウクラスを登録し,成功/失敗コードを返します */
   return (RegisterClass(&wc));
 }
 HWND InitInstance(HINSTANCE hInstance, int nCmdShow)
 {
   HWND  hWnd; // メインウィンドウのハンドル
   /* このアプリケーションインスタンスのメインウィンドウを作成します  */
   hWnd = CreateWindow(
    "Example",                 // RegisterClass() 呼び出しを参照してください
    "Example _heapset 32 bit only",  // ウィンドウのタイトルバーのテキスト
    WS_OVERLAPPEDWINDOW,        // ウィンドウスタイル
    CW_USEDEFAULT,         // デフォルトの水平位置
    CW_USEDEFAULT,          // デフォルトの垂直位置
    CW_USEDEFAULT,            // デフォルトの幅
    CW_USEDEFAULT,        // デフォルトの高さ
    NULL,                  // オーバーラップウィンドウに親はありません
    NULL,                  // ウィンドウクラスのメニューを使用します
    hInstance,              // このインスタンスはこのウィンドウを所有しています
    NULL                   // ポインタは必要ありません
   );
   /* ウィンドウを作成できなかった場合は,「failure」を返します */
   if (!hWnd)
    return (FALSE);
   /* このウィンドウを表示するには,クライアント領域を更新し,「success」を返します */
   ShowWindow(hWnd, nCmdShow); // ウィンドウを表示します
   UpdateWindow(hWnd);     // WM_PAINT メッセージを送信します
   return (hWnd);        // PostQuitMessage からの値を返します
 }
 void ExampleHeapSet(HWND hWnd)
 {
   int hsts;
   char *buffer;
   if ( (buffer = (char *)malloc( 1 )) == NULL )
     exit(0);
   hsts = _heapset( 'Z' );
   switch (hsts)
   {
     case _HEAPOK:
       MessageBox(hWnd,"Heap is OK","Heap",MB_OK|MB_ICONINFORMATION);
       break;
     case _HEAPEMPTY:
       MessageBox(hWnd,"Heap is empty","Heap",MB_OK|MB_ICONINFORMATION);
       break;
     case _HEAPBADNODE:
       MessageBox(hWnd,"Bad node in heap","Heap",MB_OK|MB_ICONINFORMATION);
       break;
     default:
       break;
   }
   free (buffer);
 }
 #pragma argsused
 LRESULT FAR PASCAL _export MainWndProc(HWND hWnd, UINT message,
             WPARAM wParam, LPARAM lParam)
 {
   switch (message) {
     case WM_CREATE:
     {
       //_heapset の例
       ExampleHeapSet(hWnd);
       return NULL;
     }
     case WM_QUIT:
     case WM_DESTROY:  // メッセージ: ウィンドウが破棄されます
       PostQuitMessage(0);
     break;
     default:      // 処理しない場合は転送します
       return (DefWindowProc(hWnd, message, wParam, lParam));
   }
 }



移植性



POSIX Win32 ANSI C ANSI C++

+