最近使用 VS 开发 c++ 的 dll ,发现 vc++ 对野指针、空指针、未初始化内存等导致的内存错误报有特定错误码:0xCDCDCDCD, 0xDDDDDDDD, 0xFEEEFEEE, 0xCCCCCCCC, 0xABABABAB。
Google上对上述错误码的解释如下:
-
0xCDCDCDCD- Created but not initialised 未初始化的堆内存 -
0xDDDDDDDD- Deleted 引用的内存已经/对象被删除 -
0xFEEEFEEE- Freed memory set by NT's heap manager -
0xCCCCCCCC- Uninitialized locals in VC6 when you compile w/ /GZ 未初始化的栈内存 -
0xABABABAB- Memory following a block allocated by LocalAlloc()
原理
VC++ 在 Debug 方式编译的程序中,会跟踪用 new 分配的内存。新分配的内存会用 0xcd(Cleared Data)填充,防止未初始化。当它被 delete 后,又会被 0xdd (Dead Data)填充,防止再次被使用。这样有利于调试内存错误。之所以选这样的填充模式,是因为:
- 大数,若被当成指针就会越界
- 奇数,指针通常指向偶数地址
- 非0, 这样不会和 NULL 混淆。
在 Release版中不会有这些字节填充