- 当class with pointer object时,自己必须重写拷贝构造,拷贝赋值,析构函数(我们以string类为例讲解)
class string{
public:
string(const char* str=0);
string(const string& str);
string& operator=(const string& str);
~stirng();
private:
char* m_data;
};
//为什么要重写拷贝构造或者拷贝赋值函数?
string a("hello");
string b("world");
b=a;
//如果使用默认的拷贝构造,与拷贝赋值函数的话,b=a将进行一对一的拷贝,所以指向a的指针指向b,导致有两个指针指向b,而a无指针可指向。当其中一个指针被析构的时候,另外一个指针就会成为空指针。【c++的默认的构造函数都是浅拷贝】这就是所谓的浅拷贝,就达不到我们构造或者赋值的目的了;
inline string::string(const string& str){
m_date=new char[strlen(str.m_data)+1];
strcpy(m_data,str.m_data)
}
//为什么我们要重写析构函数呢?因为当我们手动new了一块内存,如果没有在析构函数中手动释放,那么就会造成内存泄漏!
//重写拷贝赋值函数
inline string& string::operator=(const string& str){
if(this==&str);
return *this;//自我赋值检测
delete[]m_data;
m_data=new char[strlen[str.m_data+1]];
strcpy(m_data,str.m_data);
return *this;
}
|