Анализирам дъмп, който показва нещо странно: изглежда има противоречие между командата !heap -x -v hexadecimal_address
и !heap -flt s size_of_block
Питам за висящи показалки. В този дъмп този висящ указател се оказа: 0x0bdd00c0
За да извлека информация за блока на паметта на купчина, използвам !heap -x -v 0bdd00c0
, който връща
Entry User Heap Segment Size PrevSize Unused Flags ----------------------------------------------------------------------------- 0bdd00b8 0bdd00c0 003b0000 0bc00000 98 20 8 busy
Което показва именно, че в този случай:
- блокът на паметта е в режим
busy
(през повечето време в другите ми дъмпове паметта е свободна тук) - блокът памет е голям
0x98
байта - блокът памет се управлява вътре в купчината
003b0000
.
Какво ме озадачава:
Когато стартирам !heap -flt s 98
(просто искам да наблюдавам други обекти, които биха имали същия размер), получавам този резултат, който не показва показалеца 0bdd00c0 на моето разследване
HEAP_ENTRY Size Prev Flags UserPtr UserSize - state _HEAP @ 3b0000 14b24fa8 0014 0014 [01] 14b24fb0 00098 - (busy) 0bc645a8 0014 0014 [01] 0bc645b0 00098 - (busy) 0bc66398 0014 0014 [01] 0bc663a0 00098 - (busy) 0bcbedf8 0014 0014 [01] 0bcbee00 00098 - (busy) 0bce2cc8 0014 0014 [01] 0bce2cd0 00098 - (busy) 0bceff88 0014 0014 [00] 0bceff90 00098 - (free) 0bdf2f78 0014 0014 [01] 0bdf2f80 00098 - (busy) 0be28c50 0014 0014 [01] 0be28c58 00098 - (busy) 0be57470 0014 0014 [00] 0be57478 00098 - (free) 0beed050 0014 0014 [01] 0beed058 00098 - (busy) 0bf1aaf0 0014 0014 [00] 0bf1aaf8 00098 - (free) 0bf214c0 0014 0014 [00] 0bf214c8 00098 - (free) 0bf99bf0 0014 0014 [00] 0bf99bf8 00098 - (free)
(Дадох ви само извадката, свързана с купчина 3b0000)
Така че стигнах до извода, че изглежда има противоречие.
Дали правя/предполагам нещо нередно? Какво мога да направя, за да разбера какво не е наред?