相信不少人调试程序的时候都遇到过这个问题,昨天本人第一次遇到这个问题,刚开始完全不懂怎么回事,查了一遍程序感觉也没有问题,于是在CSDN上搜索了这句话,经过几番尝试,终于解决了这个问题,于是今天整理了一下发表出来。
首先解释一下这句话是什么意思CRT detected that the application wrote to memory after end of the head buff:CRT是指C run-time library,至于它具体是什么东西这里可以不用管,后面的意思是 “ 检测到该应用程序使用的内存超出了所分配的堆缓冲区的大小 “,也就是操作越界了。
我们知道程序分配内存一般通过两种方法,第一种是数组形式的静态内存分配,第二种是new形式的动态内存分配。(地址池方式暂时不讨论)而我遇到的问题则是在运用new 和 delete 时候出现的,接下来给大家简单的演示一遍:
如下面几句代码
char * p = new char[2];
cin >> p;
delete[] p;
当输入为 "ab" 时,运行是没有问题的,但当输入 “abcd" 时在DEBUG模式下就出来了上面的提示并导致中断,这是因为在程序只为 new 指针分配了 2 个字节的空间,而输入 ”abcd" 时占用的四个字节的空间,也就是说操作越界了,因此 delete 该指针时就会出现错误。
上面这种情况是很容易能发现的,但有时候我们会在一个函数中使用 new ,而在另一个函数中使用 delete 中间经过了复杂的操作,很难发现是否是因为操作 new 出来的空间越界而产生这样的提示,这里有一个小技巧:即使用 _msize() 函数,它能返回 new 分配的内存空间的字节数。同样以上面为例,我们可以在 cin >> p 后面加一句话
char * p = new char[2];
cin >> p;
if (_msize(p) / sizeof(char) > 2)
cout << "out of memory.\n";
delete[] p;
当然这种方法在对该内存操作次数比较多的情况下不太方便,还要标记,而且当操作越界后 delete 指针时,编译器会产生中断,这种方法就显得有点多余,看到的仅当随便看看吧。