关于堆栈(2)

创建辅助堆栈:
HANDLE HeapCreate(
DWORD flOptions, // heap allocation attributes
SIZE_T dwInitialSize, // initial heap size
SIZE_T dwMaximumSize // maximum heap size
);
flOptions:0,HEAP_GENERATE_EXCEPTIONS,HEAP_NO_SERIALIZE
0表示默认设置,堆栈会顺序访问它自己
HEAP_NO_SERIALIZE:多个线程可以同时访问堆栈,没有把握的情况下,最好不要使用该标志,会造成堆栈数据的破坏
HEAP_GENERATE_EXCEPTIONS:在分配或者重新分配堆栈的内存尝试失败时,会引发一个异常条件
dwInitialSize:堆栈最初提交到物理存储器的内存大小,如果填入的数值不是CPU页面大小的倍数,HeapCreate会将这个函数圆整为CPU页面大小的倍数
dwMaximumSize:堆栈的最大大小,如果设置为0,表示没有上限

在堆栈中分配内存
LPVOID HeapAlloc(
HANDLE hHeap, // handle to private heap block
DWORD dwFlags, // heap allocation control
SIZE_T dwBytes // number of bytes to allocate
);
hHeap:HeapCreate返回的堆栈句柄
dwFlags:可以使用的标志有0,HEAP_GENERATE_EXCEPTIONS,HEAP_NO_SERIALIZE,HEAP_ZERO_MEMORY,前面3个就不讲了,HEAP_ZERO_MEMORY表示用0填充内存
dwBytes:你想要分配的内存字节数

改变内存大小
LPVOID HeapReAlloc(
HANDLE hHeap, // 堆栈句柄
DWORD dwFlags, // heap reallocation options
LPVOID lpMem, // 想要改变大小的内存地址
SIZE_T dwBytes // 想要分配的字节数
);
dwFlags:除了HeapAlloc可以使用的标志之外还有一个HEAP_REALLOC_IN_PLACE_ONLY,这个标志告诉函数,当内存扩大时,不移动内存块

获取内存块的大小
DWORD HeapSize(
HANDLE hHeap,
DWORD dwFlags, //0或者HEAP_NO_SERIALIZE
LPCVOID lpMem // 想要获取大小的内存地址的指针
);

释放内存块
BOOL HeapFree(
HANDLE hHeap,
DWORD dwFlags, //0或者HEAP_NO_SERIALIZE
LPVOID lpMem // 想要释放的内存的地址
);

撤销堆栈
BOOL HeapDestroy(
HANDLE hHeap
);

如果进程中含有多个堆栈,可以用这个函数获取多个堆栈的句柄
DWORD GetProcessHeaps(
DWORD NumberOfHeaps, // 堆栈句柄数组的最大容量
PHANDLE ProcessHeaps // 堆栈句柄数组
);

验证堆栈的完整性
BOOL HeapValidate(
HANDLE hHeap, //
DWORD dwFlags, // 只能为0或者HEAP_NO_SERIALIZE
LPCVOID lpMem // 如果这个参数为NULL,就验证整个堆栈的完整性,否则就验证某块内存的有效性
);

合并地址中的空闲内存块,收回不包含已经分配的内存块的物理存储器页面
UINT HeapCompact(
HANDLE hHeap,
DWORD dwFlags // 只能为0或者HEAP_NO_SERIALIZE
);

锁定堆栈
BOOL HeapLock(HANDLE hHeap);
BOOLHeapUnLock(HANDLE hHeap);
这两个函数时用于线程同步的,当某个线程调用了HeapLock函数时,该线程就成为了这个堆栈的拥有者,其他线程一旦调用就会进入暂停状态,直到使用HeapUnLock

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章