偷懒的办法处理拷贝构造函数与赋值函数

2024-07-28

偷懒的办法处理拷贝构造函数与赋值函数

1.偷懒的办法处理拷贝构造函数与赋值函数 篇一

编写类String 的构造函数、析构函数和赋值函数

已知类String 的原型为:

class String

{

public:

String(const char *str = NULL); // 普通构造函数

String(const String &other); // 拷贝构造函数

~ String(void); // 析构函数

String & operate =(const String &other); // 赋值函数

private:

char *m_data; // 用于保存字符串

};

请编写String 的上述4 个函数,

标准答案:

// String 的.析构函数

String::~String(void) // 3 分

{

delete [] m_data;

// 由于m_data 是内部数据类型,也可以写成 delete m_data;

}

// String 的普通构造函数

String::String(const char *str) // 6 分

{

if(str==NULL)

{

m_data = new char[1]; // 若能加 NULL 判断则更好

*m_data = ‘�’;

}

else

{

int length = strlen(str);

m_data = new char[length+1]; // 若能加 NULL 判断则更好

strcpy(m_data, str);

}

}

// 拷贝构造函数

String::String(const String &other) // 3 分

{

int length = strlen(other.m_data);

m_data = new char[length+1]; // 若能加 NULL 判断则更好

strcpy(m_data, other.m_data);

}

// 赋值函数

String & String::operate =(const String &other) // 13 分

{

// (1) 检查自赋值 // 4 分

if(this == &other)

return *this;

// (2) 释放原有的内存资源 // 3 分

delete [] m_data;

// (3)分配新的内存资源,并复制内容 // 3 分

int length = strlen(other.m_data);

m_data = new char[length+1]; // 若能加 NULL 判断则更好

strcpy(m_data, other.m_data);

// (4)返回本对象的引用 // 3 分

return *this;

}

上一篇:法学院三年工作汇报稿下一篇:第二册《识字》教案