下午处理一个新需求,得给一个已有的类加个WORD成员变量,一不小心竟写成了DWORD。本来也没什么,很容易就能发现的问题,想不到delete的时候,程序竟飞掉了,提示“Debug Error! DAMAGE: after Normal block (#xx) at 0xXXXXXXXX”,错误在MSDN上找不到。既然改就先把已知的问题改掉吧,DWORD改回WORD,一编译,问题竟解决了,再改回来,又出现。看了并不是偶然现象,找了半天代码,没有发现类内内存有可能出问题的操作,竟是些赋值而已。于是试着在类的成员变量上找问题,包括改变顺序、用WORD然后增加一些变量、把前面的BYTE改成DWORD以保证4字节的对齐……有些不死有些死,找不出什么规律。
追踪飞掉时的栈,还在VC的安装目录指定了一些文件的目录(ft,为什么默认的定位是错误的?),总算有些收获,这个错误是说分配的内存后面的4个0xfd被改掉了,即内存访问越下界了。知道问题就好办了,看着实例的内存,一步一步查吧,最后一个很明显没问题的成员的赋值改变了这4个0xfd。难道new出来的内存大小不够?除非这个类还有另外的申明。搜索工程目录下,还真就找到了这个头文件另外的备份,调用的地方引用的还真就是这个没有修改的头文件,按照这个头文件里没有增加变量的定义分配出来的内存,自然是不够的。。至于为什么用WORD没问题,分析了一下前面有两个BYTE的成员变量,加一个WORD编译器优化过后,实际需要的内存没有增加。