为什么我们需要覆盖terminate()?

时间:2011-10-20 22:22:51

标签: c++ linux memory memory-leaks

我的C ++程序有错误:

#include<iostream>
using namespace std;

 char* foo()
 {
    char * mystr = new char[6];
    mystr = "Hello";
    return mystr ;
 }
 int main()
 {

 char* myString =foo();
 printf("%s \n", myString);

 delete [] myString ;

 } 


  ==27472== Invalid free() / delete / delete[]
  ==27472==    at 0x4A07A12: operator delete[](void*) (vg_replace_malloc.c:409)
  ==27472==    by 0x4007EB: main (printHello.cpp:16)
  ==27472==  Address 0x4008f8 is not stack'd, malloc'd or (recently) free'd

如果删除delete [] myString ;,则效果很好。

我应该释放堆上分配的内存,对吗?

但是,如果我删除它,为什么我会收到错误。

由于

2 个答案:

答案 0 :(得分:8)

因为您正在删除未分配的内存。您通过“new”分配6个字节,但随后将var“mystr”重新分配给一个完全不同的指针(静态字符串“Hello”),该指针未由“new”分配。因此,您尝试“删除”首先未由您分配的静态字符串“Hello”。这是修复:

更改这些行:

 char * mystr = new char[6]; 
 mystr = "Hello"; 

对此:

char * mystr = new char[6]; 
strcpy(mystr, "Hello");

或者,你可以让“foo”只是“返回”你好“; ”而不是删除main中的字符串。

答案 1 :(得分:3)

myString没有在堆上分配 - foo在堆上分配一个char数组,但是你扔掉指向它的指针并返回一个指向静态字符串的指针(这是不在堆上。)