Effective C++ 条款10: 令operator= 返回一个reference to *this

拷贝操作符AdvString operator= (AdvString &str)

 

#define _CRT_SECURE_NO_WARNINGS


#include <string>
using namespace std;


class AdvString
{
public:
	AdvString()
	{
		len = 128;
		m_p = new char[len];
		strcpy(m_p, "");
	}
	AdvString(const char *p)
	{
		len = strlen(p) + 1;
		m_p = new char[len];
		strcpy(m_p, p);
	}
	AdvString(const AdvString &str)
	{
		this->len = str.len;
		m_p = new char[len];
		strcpy(m_p, str.m_p);
	}
	~AdvString()
	{
		delete[]m_p;
	}
	AdvString operator= (AdvString &str)
	{
		if (&str == this)
		{
			return *this;
		}
		delete[]m_p;
		int len = str.len;
		this->m_p = new char[len];
		strcpy(m_p, str.m_p);
		return *this;
	}
private:
	char *m_p;
	int len;
};

int main()
{
	AdvString advString;
	AdvString advString01 = advString;
	AdvString advString02;
	advString02 = advString;
}

 

AdvString &operator= (const AdvString &str)
{
	if (&str == this)
	{
		return *this;
	}
	delete[]m_p;
	int len = str.len;
	this->m_p = new char[len];
	strcpy(m_p, str.m_p);
	return *this;
}


省去一次拷贝构造函数和一次析构函数

 

另外还有一个好处就是:你可以把赋值操作符写成连锁的

比如string1 = string2 = string3

 

为了实现连锁赋值,赋值操作符必须返回一个reference指向操作符的左侧实参

这个协议不仅适用于以上的标准赋值形式,也适用于所有赋值相关运算,例如operator+=, operator-=等。
这只是个协议,并无强制性,但是这份协议被所有内置类型和标准程序库提供的类型如string,vector等共同遵守。


const int &getLen()
{
        return len;
}

advString01.getLen() = 2;

 

IntelliSense: expression must be a modifiable lvalue 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值