拷贝构造函数参数不允许传值

#include <iostream>
using namespace std;


class A
{
public:
	int value;
	A(int n) { value = n; }
	A(A other) { value = other.value; }
	void print()
	{
		cout << value;
	}

};


int main()
{
	A a(10);
	A b= a;
	b.print();
}

编译器会报错:

原因:若允许传入值,则在参数传递时会继续调用拷贝构造函数,形成无限递归。

解决方案:传入引用即可,A  &other。

来自剑指offer p24。

重载“=”运算符:
 

using namespace std;


class A
{
public:
	int value;
	A(int n) { value = n; }
	A(A &other) { value = other.value; }
	void print()
	{
		cout << value;
	}

	A& operator=(const A &a)
	{
		this->value = a.value;
		return *this;
	}
};


int main()
{
	A a(1);
	A b = a;
	A c=b=a;
	c = b = a;
	cout << b.value<<c.value;
}

返回值为A&:不为void是为了可以连续赋值;返回引用是为了防止返回对象,返回对象会调用构造函数和析构函数导致不必要的开销。

参数为const A&:const为了防止改变传进去的对象;传入引用是为了防止传参时调用构造函数,导致不必要的开销。

main函数中,A b=a调用的是拷贝构造函数,A c=b=a,b=a调用重载=函数,A c=b调用拷贝构造函数。c = b = a;调用两次重载运算符函数。

附:剑指offer上给出的代码:(重载=)

CMyString& CMyString::operator =(const CMyString &str)
{ 
    if(this == &str) 
        return *this: 
    delete []m_pData; 
    m_pData = nullptr;
    m_pData = new char[strlen(str.m_pData) + 1]; 
    strcpy(m _pData, str.m _pData); 
    return *this;
}

先判断当前实例和参数是不是同一个,如果是同一个直接返回,因为下面有删除内存操作,若是同一个则当前实例的内存被释放,后续再也无法找到。

其次删除之前的内存,防止之前已经分配的内存没有释放导致内存泄漏。

delete []m_pData; 释放之前分配的内存
m_pData = nullptr;将指针置为空,若没有此步该指针为悬挂指针,指向已经释放了内存的地址,会报错。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值