您好,登录后才能下订单哦!
这篇文章主要为大家展示了“C++ 中类的拷贝、赋值、销毁如何实现”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C++ 中类的拷贝、赋值、销毁如何实现”这篇文章吧。
C++ 中类的拷贝、赋值、销毁的实例详解
如果我们没有定义类的拷贝构造函数的话,那么编译器会为我们合成默认拷贝构造函数----合成拷贝构造函数。
和成拷贝构造函数的操作是将其参数的各个成员拷贝到正在创建的对象中去,每个成员的类型决定了他是如何被拷贝的:对类类型的成员,会使用其拷贝构造函数,内置类型的成员则是直接拷贝,虽然我们不能直接拷贝一个数组,但是合成拷贝构造函数会逐个的拷贝一个数组类型的成员。
下面我们用代码演示一下合成拷贝构造函数的功能:
#include <iostream> using namespace std; /* 代码模仿合成拷贝构造函数的功能 */ class Sales_data { public: Sales_data(); //我们只是为了读者更好的理解还原了一下合成拷贝构造函数所实现的功能,实际上我们是看不见的 Sales_data(const Sales_data& s); ~Sales_data(); private: string bookNo; int units_sold = 0; double revenue = 0.0; }; Sales_data::Sales_data() { } Sales_data::Sales_data(const Sales_data& s) : bookNo(s.bookNo), units_sold(s.units_sold), revenue(s.revenue){ } Sales_data::~Sales_data() { }
好了,我们定义拷贝构造函数也是如此定义的,我解释一下为什么参数表里面是一个静态的引用:
1)我们不想改变该引用的值,只是用来进行拷贝。
2)我们必须声明为引用,如果写成类的话,则又会调用该类的拷贝构造函数,在那个拷贝构造函数中又会调用拷贝构造函数,这样陷入死循环。
我们在来学习一下拷贝赋值运算符:
和拷贝构造函数一样,如果我们不定义拷贝赋值运算符的话,编译器将会为我们合成一个,我们下面用代码来模仿一下吧:
#include <iostream> using namespace std; /* 代码模仿拷贝赋值运算符 */ class Sales_data { public: Sales_data(); //拷贝赋值运算符的默认合成 Sales_data& operator = (const Sales_data & s); ~Sales_data(); private: string bookNo; int units_sold = 0; double revenue = 0.0; }; Sales_data::Sales_data() { } Sales_data& Sales_data::operator = (const Sales_data & s) { //为什么我们的返回值一定是引用类型呢?这是因为我们可以进行链式编程而做的:s1 = s2 =s3; bookNo = s.bookNo; units_sold = s.units_sold; revenue = s.revenue; return *this; } Sales_data::~Sales_data() { }
好了,我们定义拷贝赋值运算符也是如此,我们就不一一赘述了。
我来在来谈一谈;类的构造函数初始化和类的析构函数销毁过程的一些细节性问题。
1比如我们定义了一个构造函数,实际上在参数化赋值列表处及大括号之前,才是我们真正进行初始化的地方,在大括号之中做的操作只是进行了拷贝赋值操作。
这一点我们要清楚的认识到,要不然在对const对象进行初始化是就有问题了,因为const对象只能初始化。
2比如我们定义了一个析构函数,注意了,我们在() {之间的部分才是做了真正的类成员变量的析构操作,{}里面使我们进行的自定义操作,不一定是什么析构,应为析构基本已经完成了。
以上是“C++ 中类的拷贝、赋值、销毁如何实现”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。