为何?
0x391ec0开始是相邻的下一个空闲堆块,即HEAP_FREE_ENTRY结构,391ec8处是这个结构的FreeList字段;发生溢出前,FreeList字段的内容是0x390178-0x390178,也就是下一个空闲块的地址,0x390178-8是那个块的HEAP_FREE_ENTRY结构(因为FreeList字段在结构内的偏移是8);发生溢出后,FreeList字段变成了0x2b2a2928-0x2f2e2d2c,但是堆管理器不知道溢出,仍然把0x2b2a2928-8当作是下个空闲块的HEAP_FREE_ENTRY结构,但是读取这个地址时失败了,因此显示那句话:
Unable to read nt!_HEAP_FREE_ENTRY structure at 2b2a2920