内存管理[5]

本例在建立一个新的堆前后分别通过 GetProcessHeaps 函数获取了当前进程的堆句柄列表, 没想到一个最简单的程序也有 5 个堆.

效果图:

内存管理[5]

unit Unit1;



interface



uses

  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,

  Dialogs, StdCtrls;



type

  TForm1 = class(TForm)

    Memo1: TMemo;

    Memo2: TMemo;

    Button1: TButton;

    procedure FormCreate(Sender: TObject);

    procedure Button1Click(Sender: TObject);

  end;



var

  Form1: TForm1;



implementation



{$R *.dfm}



{把下面两个过程公用的部分提取为一个独立的过程}

procedure GetHeaps(List: TStrings);

var

  HeapArr: array[0..9] of THandle; {对列表数组, 先假定有 10 堆}

  n: Integer;

  i: Integer;

begin

  {获取进程中的堆列表; 函数的参数1是数组大小, 参数2是数组的第一个元素, 返回堆的实际数量}

  n := GetProcessHeaps(Length(HeapArr), HeapArr[0]);

  List.Add(Format('当前进程共有 %d 个堆', [n]));



  List.Add('它们的句柄分别是:');



  for i := 0 to n - 1 do

    List.Add(IntToStr(HeapArr[i]));

end;





procedure TForm1.FormCreate(Sender: TObject);

begin

  Memo1.Clear;



  {调用公用过程, 在 Memo1 中显示堆句柄列表}

  GetHeaps(Memo1.Lines);



  {再次添加默认堆的句柄}

  Memo1.Lines.Add('');

  Memo1.Lines.Add('默认堆的句柄是:');

  Memo1.Lines.Add(IntToStr(GetProcessHeap));

end;





procedure TForm1.Button1Click(Sender: TObject);

var

  MyHeap: THandle;

begin

  {创建新堆}

  MyHeap := HeapCreate(0, 1024*1024*2, 0); {建立个 2M 的堆}



  Memo2.Clear;



  {调用公用过程, 在 Memo2 中显示堆句柄列表}

  GetHeaps(Memo2.Lines);



  {再次添加新建堆的句柄}

  Memo2.Lines.Add('');

  Memo2.Lines.Add('新建堆的句柄是:');

  Memo2.Lines.Add(IntToStr(MyHeap));



  {销毁新建堆}

  HeapDestroy(MyHeap);

end;



end.


 
   

你可能感兴趣的:(内存管理)