发布网友 发布时间:2022-06-12 22:43
共1个回答
热心网友 时间:2023-10-10 11:10
如果编译器报这样的错,几乎可以肯定是在程序中,数组访问越界。例如:
int main()
{
int *p=new int[5];
p[-1]=3;
delete [] p;
return 0;
}
当执行至delete 语句时,就会弹出上图那个对话框,报damage before normal block
如果程序修改成这样
int main()
{
int *p=new int[5];
p[5]=3;
delete [] p;
return 0;
}
执行至delete语句时,则会报damage after normal block 的错误。
什么是normal block?在使用new 操作符为指针申请内存空间时,VC编译器为该指针分配的内存空间就是normal block。这段内存空间每个字节的初始值均为 CD h 。并且把该段内存空间之前4个字节和之后4个字节
的初值赋值为FDFDFDFD h。
用VC的Memory工具可以方便地查看到这段新分配的内存空间的内容。如上面的两个程序,VC为指针p申请的内存空间地址从0x00032f48起始。用Memory查看这个地址附近的内容,就是下图显示的内容:
在用delete 释放该段内存空间时,编译器会检查该段内存之前4个字节内容和之后4个字节内容是否有被改动。如果有,则分别报damage before normal block和damage after normal block。
但是,VC编译器的这种检错功能是十分有限的,防止数组访问越界,主要靠程序员自己小心。如上面的
程序中,如果让p[-2]=3,即对内存地址0x00032F44之前的内存进行改动,编译器是检测不出这样的错误的。同理,对p[6]赋值,或者将p[5]=0xFDFDFDFD,编译器都不会报错的。
追问我可以给你程序你帮我看看问题在哪么??那怎么修改才行啊