|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 qq1242009750 于 2018-2-9 22:49 编辑
移动构造函数
大家听过构造函数,但在C++11标准后出现了一个 移动构造函数 那这个函数有什么用呢? 接下来我们一起分析分析:
移动? 什么意思呢 顾名思义就是移动他 而不是 复制他(相当于一个浅拷贝)
那我们普通的构造函数呢
从图上可以看出,相当于复制了一个副本。
那什么时候移动构造函数会工作呢?
答:那就是遇到将亡值的时候且又要构造一个对象的时候。
将亡值就是通过函数返回的值,也可以是一个匿名变量(没有名字的变量)。
例如:
- CA p()
- {
- CA a;
- return a;
- }
复制代码
此函数会返回一个将亡值。
那么移动构造函数怎么定义呢?
只要在普通的拷贝构造函数的参数里 去掉const 在再加上一个 & 就可以了
好,我们知道了如何定义移动构造函数了,那么我们该怎样写他的内容呢?
首先我们定义一个类
- CA
- {
- public:
- CA(CA &&oth);
- CA();
- ~CA();
- private:
- char *name;
- }
复制代码
然后再把 他们的函数给补上:
- CA(CA &&oth):name(oth.name)
- {
- oth.name = nullptr;
- cout << "CA(CA &&)" << endl;
- }
复制代码
- CA()
- {
- name = new char[4];
- strcpy(name, "GSD");
- cout << "CA()" << endl;
- }
复制代码
- ~CA()
- {
- delete[] name;
- cout << "~CA()" << endl;
- }
复制代码
为什么要把oth.name 赋值 nullptr 呢?
是因为我们直接把将亡值的内容移动到了另一个对象中了,如果不赋nullptr,当匿名函数析构的时候会把堆给释放,那么使用移动构造函数就没有意义了。
为什么要使用移动构造函数:这样做可以减少堆空间的创建和删除,换句话说就是提高我们的效率,然后匿名函数析构。
下面给出测试的代码:
- #include <iostream>
- using namespace std;
- int g = 0;
- class CA
- {
- public:
- CA()
- {
- name = new char[4];
- strcpy(name, "GSD");
- cout << "CA()" << m_i << endl;
- }
- CA(const CA &oth)
- {
- name = new char[4];
- strcpy(name, "GSD");
- cout << "CA(const CA &)"<< m_i << endl;
- }
- CA(CA &&oth):name(oth.name)
- {
- oth.name = nullptr;
- cout << "CA(CA &&)" << m_i << endl;
- }
-
- ~CA()
- {
- delete[] name;
- cout << "~CA()" << m_i << endl;
- }
- private:
- int m_i = ++g;
- char *name;
- };
- CA p()
- {
- CA a;
- return a;
- }
- int main(void)
- {
- CA a(p());
- system("pause");
- return 0;
- }
复制代码 |
|