本例在建立一个新的堆前后分别通过 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.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧