2
我正在關注如何在C中製作內存掃描器的簡單教程。由於某種原因,我的主循環從未發生過。C內存掃描器[無限循環]
下面是代碼
MEMBLOCK* create_scan(unsigned int pid){
MEMBLOCK *mb_list = NULL;
MEMORY_BASIC_INFORMATION meminfo;
unsigned char *addr = 0;
HANDLE hProc = OpenProcess (PROCESS_ALL_ACCESS, FALSE, pid);
if(hProc){
while(1){
// print the address for debug purpose
printf("%d \r\n", addr);
// loop should break out when the address overflows (return 0)
if(VirtualQueryEx (hProc, addr, &meminfo, sizeof(meminfo)) == 0){
break;
}
#define WRITABLE (PAGE_READWRITE | PAGE_WRITECOPY |PAGE_EXECUTE_READWRITE | PAGE_EXECUTE_WRITECOPY)
if ((meminfo.State & MEM_COMMIT) && (meminfo.Protect & WRITABLE)){
MEMBLOCK *mb = create_memblock (hProc, &meminfo);
if(mb){
mb->next = mb_list;
mb_list = mb;
}
}
addr = (unsigned char*)meminfo.BaseAddress + meminfo.RegionSize;
}
}
return mb_list;
}
出於某種原因,輸出(printf的)這是
123863040
125943808
... until ...
2147418112
... all on the sudden ...
-1207959552
...
-243924992
0
65536
loop start again
任何想法,我有點迷路了!
如果地址太高,會產生錯誤否? 非常感謝我解釋我的結果,至少我明白了奇怪的結果......我總是想知道人們是如何知道所有這些東西的。 –
謝謝,我使用SYSTEMINFO lpMaximumApplicationAddress打破了我的循環。欣賞它。 –