• 全部
  • VC综合技术
  • 互联网技术
  • MFC AppLauncher
  • .NET 技术
  • 界面
  • 进程
  • 算法
  • 硬件/系统
  • 数据库
  • VC++技术资源

谁知道在Debug方式下这样的错误是什么意思?.........

runbuff 2001-07-12 01:31:54
我有一个程序,在win2000下用VC6开发,在Debug方式下,结束某一函数时总是出现如下错误:DEMAGE after Normal block(#113) at 0x9529D0 ,在Release下则没有这个错误。
请问这个错误产生的原因是什么,怎样解决??
...全文
151 点赞 收藏 12
写回复
12 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
runbuff 2001-07-13

我的函数中只是用了CString strTmp,
还有strTmp.GetBufferSetLength(MAX_PATH)、strTmp.ReleaseBuffer()之类的调用。
把定义改为static CString strTmp就正常了。
谢谢大家。
回复
david4no 2001-07-12
可能是由于你的程序中有!ASSERT(0),VERIFY(0〔一类的调试语句这样的语句在release版本下是不被编译的!但是在debug状态下会弹出一个调试对话框!让你有机会进入调试状态
回复
wjyasd 2001-07-12
难道是少了‘\0'的缘故?

char a[10]; //只能保存9个字符,要是保存10个的话,在你NEW了结构使用之后
//释放的时候就会抱错! 一定要保证最后是'\0' ^&^
回复
flagfly 2001-07-12
看看返回值的变量是否越界
回复
Kevin_qing 2001-07-12
可以在出现错误的时候看看call stack,一般都可以查处问题
回复
runbuff 2001-07-12

Kevin_qing(Kevin),谢了。
我再找找看。
回复
Kevin_qing 2001-07-12
在看看
struct A{
A(LPCSTR str){
m_str=new char[10];
strcpy(m_str,str);
}
~A(){delete []m_str;}
char* m_str;
};


void main()
{
A a("1234567890");//已经写越界了,但是现在还未检查到

}//函数结束时自动释放a,在~A()里面调用delete检查到错误
回复
runbuff 2001-07-12
To Kevin_qing(Kevin):
我跟踪过了,错误发生在函数结束时,此时没有写数据的动作。仅仅是返回函数值。
回复
Kevin_qing 2001-07-12
写内存越界了。
比如
char *pStr=new char[100];

pStr[100]=0;
delete pStr;//运行到这里就会报错
回复
zeroweb 2001-07-12
可能是你的2000或VC有问题
回复
zcpro 2001-07-12
关注!
回复
runbuff 2001-07-12
请高手指教。
本菜鸟这厢有礼了。
回复
相关推荐
发帖
VC/MFC
创建于2007-09-28

1.5w+

社区成员

VC/MFC相关问题讨论
申请成为版主
帖子事件
创建了帖子
2001-07-12 01:31
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……