Chinaunix首页 | 论坛 | 博客
  • 博客访问: 9728054
  • 博文数量: 1227
  • 博客积分: 10026
  • 博客等级: 上将
  • 技术积分: 20273
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-16 12:40
文章分类

全部博文(1227)

文章存档

2010年(1)

2008年(1226)

我的朋友

分类: C/C++

2008-04-23 21:37:14

为什么要在operator=中返回"*this"的引用
作者:



[问题的提出]:
在很多书籍和文章中,很多次提到在对赋值操作符(=)进行重载的时候,要返回对目的(调用)对象实例(*this)的引用。其中不免有这样的论断:一定要返回对调用对象的引用;返回对调用实例对象的引用是为了实现链式连续赋值。
这里说明两个问题:第一,是否重载赋值操作符必须返回对调用对象的引用,第二,是否这样就可以实现链式赋值,而不这样就不行。
首先,必须承认,返回对"*this"的引用是标准的二目操作符重载的格式,效率很高。这样做有很多优点:如实现链式赋值、避免临时对象的产生(调用拷贝构造函数)、销毁(调用析构函数),但不是非这样做不可,下面通过对比来论述返回对"*this"的引用的优点及其他做法的缺点,同时也能清楚第二个问题,我们从例子着手。

// a.h

class A  

{

public:

A();

	A(int nTest);

	A(const A& a);

	virtual ~A();

	A operator=(const A& a);

	// A& operator=(const A& a);



private:

	int m_nTest;

	

public:

	void printit();

};

}



// a.cpp

A::A(int nTest)

{

	m_nTest = nTest;

	cout << "constructor A Value is executed now!" << endl;

}



A::A(const A& a)

{

	this->m_nTest = a.m_nTest;

	cout << "Copy constructor A is executed now!" << endl;	

}



A::A()

{

	cout << "constructor A Default is executed now!" << endl;

}



A::~A()

{

	cout << "Destructor A is executed now!" << endl;

}

A A::operator=(const A& a)

// A& A::operator=(const A& a)

{

	if (this==&a)  

	return *this;

	this->m_nTest = a.m_nTest;

	cout << "Assignment A is  

executed now!" << endl;

	return *this;

}

在main()函数中调用
A a(100),b(99),c(98);

a = b = c;

a.printit();

b.printit();

c.printit();

结果为:
constructor A Value is executed now!
constructor A Value is executed now!
constructor A Value is executed now!
Assignment A is executed now!
Copy constructor A is executed now!
Assignment A is executed now!
Copy constructor A is executed now!
Destructor A is executed now!
Destructor A is executed now!
99
99
98
Destructor A is executed now!
Destructor A is executed now!
Destructor A is executed now!
阅读(271) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~