int main()
{
int *p=new int[5]
p[-1]=3
delete [] p
return 0
}
当执行至delete 语句时,就会d出上图那个对话框,报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,编译器都不会报错的。
应用程序无法正常启动0xc0000142解决方法:1、打开“运行”输入→cmd→回车
2、然后把下面这行字符复制到黑色cmd框里面去回车等待dll文件全部注册完成就关闭可以了,为防止输入错误可以复制这条指令,然后在命令提示符后击鼠标右键→粘贴→回车,耐心等待,直到屏幕滚动停止。
(下面是要运行的代码):
for
%1
in
(%windir%\system32\*.dll)
do
regsvr32.exe
/s
%1
3、完成后重新启动机器。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)