VC中由memset引起内存溢出错误的解决 by wangxg
最近用VC写了一个小程序,release没有问题,debug时就出现问题了,而且是程序中很常见也是很棘手的问题:内存溢出。这种高级问题被我撞见,真是荣幸啊!但由于对VC接触不深,或者语言基础不牢的缘故吧,最终还是没有搞定。只好请来朋友帮忙了,今天终于圆满,记下备查。
症状描述:
- 运行时会出现一个对话筐:
Degug Error!
Program:C:xxxxxx.exe
DAMAGE: after normal block(#513) at 0x003DB080.(Press Retry to debug the application)
- 点击重试之后就会出现一个windows的标志性对话筐,“……程序遇到问题需要关闭,我们对此引起的不便表示抱歉……”,点“调试”之后会出现:
应用程序发生异常unknown software exception (0x80000003), 位置为0x1021376f。
要终止程序,请单击确定。 - 单击“确定”退出,degug窗口会显示退出状态为:
The thread 0xE20 has exited with code -2147483645 (0x80000003).
The thread 0xC84 has exited with code -2147483645 (0x80000003).
The program ''E:VCxxx.exe'' has exited with code -2147483645 (0x80000003).
问题代码:
我的代码片断如下
char* szData = (char*)malloc((CHAR_LEN + 1) * sizeof(char)); if(szData == NULL) {
PRINTMSG("memory error!");
return;
}
......
memset(szData, 0, strlen(szData));
free(szData);
问题解决:
诈一看代码并没有问题,可是调试时却发现内存无法释放!到底时什么问题呢?我一开始认为是malloc的问题,可是把动态分配的指针改为数组之后,问题依旧。这下可就难办了。究竟是什么原因引起的呢?我无意间发现,还有一个memset没有注意到,于是把它注释掉,编译,运行……,那个可恶的对话框竟然没有了!难道申请内存之后初始化错了吗?仔细看了一下,却是问题就处在它身上。
memset(szData, 0, strlen(szData));
由于malloc分配的内存空间并没有初始化,所以它所指向的内容是不可预知的。而strlen在遇到字符null时才会返回,所以memset并不能有效的初始化我们所希望的内存空间。由于strlen返回值的不确定性,memset在对szDate初始化时就会出错。于是我把memset改为:
memset(szData, 0, CHAT_LEN + 1);
问题就解决了。
结论:此次问题的出现,就是对基础语言及语言规则掌握不牢所致,所以编译器只是一种工具,他能给你提供方便,但是最重要的还是对语言的掌握