C++ 拷贝构造函数和重载赋值操作符相互调用分析 [转]
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了C++ 拷贝构造函数和重载赋值操作符相互调用分析 [转],小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2970字,纯文字阅读大概需要5分钟。
内容图文
![C++ 拷贝构造函数和重载赋值操作符相互调用分析 [转]](/upload/InfoBanner/zyjiaocheng/1145/58615f3554fa494ba6b2e634f5dddfd5.jpg)
结论:
从面相对象编程的角度考虑,拷贝构造函数调用重载赋值操作符,重载赋值操作符调用拷贝构造函数的写法都是没有意义的。应该避免。
Don‘t try to implement one of the copying functions in terms of the other. Instead, put common functionality in a third function that both call.
——Effective C++ Third Edition By Scott Meyers Item 12: Copy all parts of an object Things to Remember
首先明确:拷贝构造函数的存在意义是通过已有的对象构造新的对象,构造完毕后才有两个对象;重载赋值操作符的意义在于将一个对象的值赋给另一个对象,两个对象都已经构造完毕了。
拷贝构造函数调用重载赋值操作符:把已有对象的值赋给一个构造中的对象,虽然这个对象的内存已经分配好了。(可以接受,但是有可能导致循环调用重载赋值操作符和拷贝构造函数)
重载赋值操作符调用拷贝构造函数:把已有对象复制并赋值给这个对象。——多一个临时对象,而且导致循环调用重载赋值操作符。
例子1:拷贝构造函数调用重载赋值操作符(导致循环调用重载赋值操作符和拷贝构造函数 )
- #include <iostream>
- using namespace std;
- class Base {
- public:
- Base() {cout << "Constructor invoked!" << endl;}
- ~Base() {cout << "Destructor invoked!" << endl;}
- Base(const Base& rhs) {
- cout << "Copy constructor invoked!" << endl;
- operator=(rhs); // *this = rhs;
- }
- Base operator=(const Base& rhs) { // 问题出在这里,返回值不是引用会调用拷贝构造函数
- cout << "Copy assignment operator invoked!" << endl;
- return *this;
- }
- };
- int main(int argc, char** argv) {
- cout << "Hello World C++!" << endl;
- Base a;
- Base b(a); // Base b = Base(a);
- return 0;
- }
修改后
- #include <iostream>
- using namespace std;
- class Base {
- public:
- Base() {cout << "Constructor invoked!" << endl;}
- ~Base() {cout << "Destructor invoked!" << endl;}
- Base(const Base& rhs) {
- cout << "Copy constructor invoked!" << endl;
- operator=(rhs); // *this = rhs;
- }
- Base& operator=(const Base& rhs) { // 返回引用,可以接受
- cout << "Copy assignment operator invoked!" << endl;
- return *this;
- }
- };
- int main(int argc, char** argv) {
- cout << "Hello World C++!" << endl;
- Base a;
- Base b(a); // Base b = Base(a);
- return 0;
- }
这样做没有任何问题,但是破坏了拷贝构造函数的意义(不同人,可能理解不同),所以不推荐。
如果你认为拷贝构造函数体内就是需要这样赋值,Ok,这样做没有任何问题。请继续。
例子2:重载赋值操作符调用拷贝构造函数(导致循环调用重载赋值操作符 )
- #include <iostream>
- using namespace std;
- class Base {
- public:
- Base() {cout << "Constructor invoked!" << endl;}
- ~Base() {cout << "Destructor invoked!" << endl;}
- Base(const Base& rhs) {
- cout << "Copy constructor invoked!" << endl;
- }
- Base& operator=(const Base& rhs) {
- cout << "Copy assignment operator invoked!" << endl;
- *this = Base(rhs);
- return *this;
- }
- };
- int main(int argc, char** argv) {
- cout << "Hello World C++!" << endl;
- Base a;
- Base b(a); // Base b = Base(a);
- b = a;
- return 0;
- }
还是那句话:
-
Don‘t try to implement one of the copying functions in terms of the other. Instead, put common functionality in a third function that both call.
拷贝构造函数是用一个已存在的对象去构造一个不存在的对象(拷贝构造函数毕竟还是构造函数嘛),也就是初始化一个对象。而赋值运算符重载函数是用一个存在的对象去给另一个已存在并初始化过(即已经过构造函数的初始化了)的对象进行赋值。 它们定义上的区别,楼上的已经说过了。
比如:String s1("hello"),s2=s1;//拷贝构造函数
Sring s1("hello"),s2;
s1=s2;//赋值运算符重载
以下情况都会调用拷贝构造函数:
1、一个对象以值传递的方式传入函数体 (形参和实参结合)
2、一个对象以值传递的方式从函数返回 (函数返回
3、一个对象需要通过另外一个对象进行初始化。
原文:http://www.cnblogs.com/linnn/p/4383782.html
内容总结
以上是互联网集市为您收集整理的C++ 拷贝构造函数和重载赋值操作符相互调用分析 [转]全部内容,希望文章能够帮你解决C++ 拷贝构造函数和重载赋值操作符相互调用分析 [转]所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。