参考自 https://blog.csdn.net/lplp90908/article/details/77876988 (他最后地方的拷贝构造函数写错了,*this这个地方,可以把这两行删除)
测试代码如下:
//21_0122 手写String 函数 拷贝构造 析构 构造
class String
{
public:
String(const char* str = NULL); //普通的构造函数
String(const String& other); //拷贝构造函数
~String();
String& operator = (const String& other); //赋值操作符
void getData();
void setData(const char* p);
private:
char* m_data;
};
String::String(const char* str)
{
if(str == NULL)
{
m_data = new char[1];
*m_data = '\0';
}
else
{
int len = strlen(str);
m_data = new char[len+1];
strcpy(m_data,str);
}
}
String::~String()
{
if(m_data != NULL)
{
delete[] m_data;
m_data = NULL;
}
}
String::String(const String& other) //思考一下为啥是引用 (明白了 这样就是效率高 这个传值也可以但是传引用快)
{
int len = strlen(other.m_data);
m_data = new char[len+1];
strcpy(m_data,other.m_data);
}
String& String::operator=(const String& other) //这种要把返回类型写在前面
{
delete[] m_data;
int len = strlen(other.m_data);
m_data = new char[len+1];
strcpy(m_data,other.m_data);
return *this;
}
void String::getData()
{
cout<<"This data is "<<m_data<<endl;
}
void String::setData(const char* p)
{
if(m_data != NULL)
{
delete[] m_data;
}
int len = strlen(p);
m_data = new char[len+1];
strcpy(m_data,p);
cout<<"after set this str is "<<m_data<<endl;
}

京公网安备 11010502036488号