头文件不一致?

    下午处理一个新需求,得给一个已有的类加个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 编译器优化过后,实际需要的内存没有增加。
 

你可能感兴趣的:(byte,编译器,delete,优化)