我有下面的代码,我不知道为什么当它遇到Myclass的析构函数时,检测到堆检测到的错误。我相信我正在释放内存?正常块后检测到堆损坏
#include <iostream>
#include <vector>
using namespace std;
class MyClass{
private:
char* mp_str;
public:
MyClass():mp_str(NULL){}
~MyClass(){
delete [] mp_str;
}
void setString(const char* str);
void printString();
};
int main(){
MyClass* a = new MyClass();
std::vector<MyClass> myVector;
myVector.push_back(*a);
a->setString("Hello World");
myVector[0].setString("Goodbye world");
a->printString();
myVector[0].printString();
return 1;
}
void MyClass::setString(const char* const str){
if(!str)
return;
size_t len = strlen(str);
if(!this->mp_str){
this->mp_str = new char[len];
memset(mp_str, 0, len+1);
}
strncpy(mp_str, str, len);
}
void MyClass::printString(){
if(this->mp_str)
cout << mp_str;
else
cout << "No string found";
}
EDIT:(固定代码)
void MyClass::setString(const char* const str){
if(!str)
return;
size_t len = strlen(str);
if(!this->mp_str){
this->mp_str = new char[len+1];
memset(mp_str, 0, len+1);
}
strncpy(mp_str, str, len);
}
在主
(),我还添加
delete a;
调用返回1之前;
需要的【三规则(http://stackoverflow.com/questions/4172722/what-是最规则的三)。 – jxh 2012-07-26 19:03:04
你也泄漏'a'中的对象 – 2012-07-26 19:03:49
@yurikilochek:同意。固定的。 – brainydexter 2012-07-26 19:08:10