内存管理五

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

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