微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何通过HANDLE来判断堆是否被序列化?

说,如果我在我的过程中调用GetProcessHeaps来获取它使用的堆列表。 有一个堆HANDLE如何判断这个堆是否是用HEAP_NO_SERIALIZE标志创build的?

如果/何时取消分配的堆内存得到回收?

JVM在32位操作系统上堆积

如何在Linux中限制ac代码的堆大小

不能改变tomcat 7的堆大小

malloc像使用自定义堆的函数

虽然不是一个明确的答案,你可以调用HeapQuery@R_157_4045@ion(HeapCompatibility@R_157_4045@ion) ,如果它返回2,那么它是序列化,因为MSDN说这个关于HEAP_NO_SERIALIZE:

使用此选项创建的堆不能启用低碎片堆(LFH)

我不知道是否有一个未公开的API来获取标志,但为了调试目的,您可以直接访问内部堆结构:

void DumpHeapType_Win8_x86(HANDLE hHeap) { typedef struct { UINT32 UnkNown1[2]; UINT32 Sig; UINT32 UnkNown2[1]; void*UnkNown3[2]; //LIST_ENTRY? void*UnkNown4[1+1+1+1+2]; UINT32 UnkNown5[1+1+1+1]; UINT32 Flags; } HEAP_HDR; typedef struct { UINT32 UnkNown1[2]; UINT32 Sig; UINT32 UnkNown2[1]; void*UnkNown3[2]; //LIST_ENTRY? HEAP_HDR*pHdr; } HEAP_THING; HEAP_THING *pThing = (HEAP_THING*) hHeap; if (hHeap && pThing->Sig == 0xffeeffee) { HEAP_HDR *pHdr = (HEAP_HDR*) pThing->pHdr; if (pHdr->Sig == 0xffeeffee) { printf("Flags=%#x Serialized=%dn",pHdr->Flags,!(pHdr->Flags & HEAP_NO_SERIALIZE)); } } } void playwithheaps() { HANDLE hHeap; DumpHeapType_Win8_x86(hHeap = GetProcessHeap()); DumpHeapType_Win8_x86(hHeap = HeapCreate(0,0)); if (hHeap) HeapDestroy(hHeap); DumpHeapType_Win8_x86(hHeap = HeapCreate(HEAP_NO_SERIALIZE,0)); if (hHeap) HeapDestroy(hHeap); DumpHeapType_Win8_x86(hHeap = HeapCreate(HEAP_NO_SERIALIZE|HEAP_GENERATE_EXCEPTIONS,0)); if (hHeap) HeapDestroy(hHeap); }

在我的Windows 8机器上,这给了我以下输出

Flags=0x2 Serialized=1 Flags=0x1002 Serialized=1 Flags=0x1003 Serialized=0 Flags=0x1007 Serialized=0

但堆结构布局可能会在其他版本不同,所以你只需要仔细测试…

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐