没有分配被释放的指针(创建类的动态副本)

时间:2016-10-01 09:52:33

标签: c++ xcode7

我需要编写一个程序,我必须创建带有元素的类,其中内存是动态分配的。当我动态创建我的类的两个实例(m1和m2)并复制m1(代码:m1 = m2)时,编译器会说下一个:

C++(11253,0x100084000) malloc: *** error for object 0x1002000b0:
pointer being freed was not allocated
*** set a breakpoint in malloc_error_break to debug
Program ended with exit code: 9

这是我的班级:

class CharArray {
private:
    char *array;
public:
//Конструкторы
CharArray() {
    array=new char[1];
}
CharArray(char *str) {
    array=new char[strlen(str)];
    strcpy(array, str);
}
CharArray(const CharArray &a) {
    array=new char[strlen(a.array)];
    strcpy(array, a.array);
}

//Деструктор
~CharArray() {
    delete [] array;
    //cout << "Сработал деструктор!" << endl;
}

//Остальные методы
//Выводит на экран содержимое массива
void ShowArray();
//Ввод данных в массив
void EnterString();
//Вывод информации о массиве
void InfoAboutArray();
int SayLength();
CharArray operator+(CharArray &secondArray) const;
//CharArray& operator=(const CharArray &a);
CharArray& operator=(const char *a);
//Делаем большие буквы мальнькими и наоборот
void UpperCaseToLowerAndLowerCaseToUpper();
//Делаем маленькие буквы большие
void AllUpperCase();
//Делаем большие буквы маленькими
void AllLowerCase();

//Перегрузка операторов new и delete
void* operator new(size_t size);
void operator delete(void *p);

void* operator new[](size_t size);
void operator delete[](void *p);
};

这是我的主要内容:

int main(int argc, const char * argv[]) {
char m[16]="Hello, World!!!";
CharArray *m1;
cout << "Динамическое создание экземпляра класса, его инициализация строкой \"Hello, World!!!\" и вывод содержимого экземпляра на экран:" << endl;
m1=new CharArray(m);
m1->ShowArray();
cout << "Создание динамической копии экземпляра класса" << endl;
CharArray *m2;
m2=m1;
cout << "Вывод содержимого копии экземпляра на экран:" << endl;
m2->ShowArray();
delete m1;
delete m2;
return 0;
}

如何解决这个问题?

2 个答案:

答案 0 :(得分:1)

主要陈述中的陈述:

m2=m1;

由于m2m1是指针,因此会将m1中的地址分配到m2

那没错,但当你:

delete m1;
delete m2;

第一个语句将破坏内存,第二个语句将尝试销毁相同的内存(因为你的指针是相同的)。

所有权存在问题:当m1释放其所有权时,您应将其设置为空(m1 = nullptr)。

这就是您的代码产生错误的原因。无论如何,代码中的内存还有其他错误(正如您在其他答案或评论中看到的那样)。

答案 1 :(得分:0)

_typeof2错了;你需要array=new char[strlen(str)];

同样适用于array=new char[strlen(str) + 1];

变量array=new char[strlen(a.array)];m1不属于m2类型;它们是指向 CharArray的类型;因此,当你做CharArray; (好吧,Biagio已经回答了,所以我放弃了。)