《windows核心编程》告诉我们,对于每个应用程序的4G虚拟空间可以分为4个大块:
0x0000 0000 ~ 0x0000 ffff:空指针赋值分区
0x0001 0000 ~ 0x7ffe ffff:用户模式分区
0x7fff 0000 ~ 0x7fff ffff:64K禁入分区
0x8000 0000 ~ 0xffff ffff:内核模式分区
但是再要具体点就需要自己研究了。
咱就来看看一个应用程序是怎么使用这4G的空间的 。先写段代码查询一下这4G空间中内存块的大致分类:
SYSTEM_INFO info;
MEMORY_BASIC_INFORMATION mi;
HANDLE hProcess;
DWORD dwAddr;
MEMORY_BASIC_INFORMATION miBlock[1000];
int nCount = 0;
hProcess = GetCurrentProcess();
GetSystemInfo(&info);
dwAddr = (DWORD) info.lpMinimumApplicationAddress;
do
{
VirtualQueryEx(hProcess, (LPCVOID) dwAddr, &mi, sizeof(mi));
memcpy(&miBlock[nCount++], &mi, sizeof(mi));
dwAddr += mi.RegionSize;
} while(dwAddr < (DWORD) info.lpMaximumApplicationAddress);
print_block_table(miBlock, nCount);
……
在这种方式下,将可以得到249个内存块,如下表所示(所有值均为 十六进制):