拷贝构造函数_重载=操作符的区别_深拷贝

#define _CRT_SECURE_NO_WARNINGS
#include"iostream"
using namespace std;

/*
	如果要考虑深拷贝问题,必须写拷贝构造函数和重载=操作符函数
	深拷贝原则:
	1.判断原内存空间是否为空,不为空则释放掉
	2.分配新的内存空间
	3.拷贝

	调用拷贝构造函数:		用对象初始化(定义的同时赋值)另一个对象时
	调用重载=操作符函数:	用一个对象赋值给另一个对象(可能已经初始化,默认或者有参构造函数)时,

*/

class Test08
{
public:

	Test08() {
		name = NULL;
		len = 0;
		cout << "默认构造函数" << endl;
	}
	Test08(char* name) {
		len = strlen(name);
		this->name = (char*)malloc(sizeof(char)*(len + 1));
		strcpy(this->name, name);
		cout << "有参构造函数" << endl;
	}

	Test08(const Test08& obj) {
		if (name != NULL) {
			free(name);
			name = NULL;
			len = 0;
		}
		len = obj.len;
		name = (char*)malloc(sizeof(char)*(len + 1));//深拷贝:手动分配内存
		strcpy(name, obj.name);
		cout << "拷贝构造函数" << endl;
	}

	~Test08() {
		cout << "析构函数" << endl;
		if (name != NULL)
		{
			free(name);
			name = NULL;
			len = 0;
		}
	}
public:

	Test08& operator=(const Test08& obj) {
		if (name != NULL)
		{
			free(name);
			name = NULL;
			len = 0;
		}
		len = obj.len;
		name = (char*)malloc(sizeof(char)*(len + 1));
		strcpy(name, obj.name);
		cout << "重载=操作符" << endl;
		return *this;
	}

	void printT() {
		puts(name);
	}
protected:
private:
	char* name;
	int len;
};

void objectShow08() {
	Test08 t1((char*)"Hello");
	//1.调用拷贝构造函数
	Test08 t2 = t1;//这里不会调用t2默认构造函数
	//2.调用重载=操作符函数
	Test08 t3;
	t3 = t1;//必须重载=操作符函数,否则析构函数出错:未加载wntdll.pdb

	t1.printT();
	t2.printT();
	t3.printT();
	//析构t3
	//析构t2(拷贝构造函数)
	//析构t1
}

int main() {
	objectShow08();	
	
	system("pause");
	return 0;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值