鱼C论坛

 找回密码
 立即注册
查看: 1993|回复: 0

[技术交流] C++11 移动构造函数

[复制链接]
发表于 2018-2-9 15:07:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 qq1242009750 于 2018-2-9 22:49 编辑

移动构造函数

大家听过构造函数,但在C++11标准后出现了一个 移动构造函数 那这个函数有什么用呢? 接下来我们一起分析分析:

移动? 什么意思呢  顾名思义就是移动他 而不是 复制他(相当于一个浅拷贝)
移动构造函数.jpg

那我们普通的构造函数呢
构造函数.jpg
从图上可以看出,相当于复制了一个副本。

那什么时候移动构造函数会工作呢?
答:那就是遇到将亡值的时候且又要构造一个对象的时候。

将亡值就是通过函数返回的值,也可以是一个匿名变量(没有名字的变量)。
例如:
  1. CA p()
  2. {
  3.         CA a;
  4.         return a;
  5. }
复制代码

此函数会返回一个将亡值。

那么移动构造函数怎么定义呢?
只要在普通的拷贝构造函数的参数里 去掉const 在再加上一个 & 就可以了
  1. CA(CA &&oth);
复制代码


好,我们知道了如何定义移动构造函数了,那么我们该怎样写他的内容呢?
首先我们定义一个类
  1. CA
  2. {
  3.    public:
  4.    CA(CA &&oth);
  5.    CA();
  6.    ~CA();
  7.     private:
  8.         char *name;
  9. }
复制代码

然后再把 他们的函数给补上:
  1. CA(CA &&oth):name(oth.name)
  2.         {
  3.                 oth.name = nullptr;
  4.                 cout << "CA(CA &&)" << endl;
  5.         }
复制代码

  1.         CA()
  2.         {
  3.                 name = new char[4];
  4.                 strcpy(name, "GSD");
  5.                 cout << "CA()" << endl;
  6.         }
复制代码

  1.         ~CA()
  2.         {
  3.                 delete[] name;
  4.                 cout << "~CA()"   << endl;
  5.         }
复制代码


为什么要把oth.name 赋值 nullptr 呢?
是因为我们直接把将亡值的内容移动到了另一个对象中了,如果不赋nullptr,当匿名函数析构的时候会把堆给释放,那么使用移动构造函数就没有意义了。
为什么要使用移动构造函数:这样做可以减少堆空间的创建和删除,换句话说就是提高我们的效率,然后匿名函数析构。

下面给出测试的代码:
  1. #include <iostream>
  2. using namespace std;

  3. int g = 0;
  4. class CA
  5. {
  6. public:
  7.         CA()
  8.         {
  9.                 name = new char[4];
  10.                 strcpy(name, "GSD");
  11.                 cout << "CA()" << m_i << endl;
  12.         }


  13.         CA(const CA &oth)
  14.         {
  15.                 name = new char[4];
  16.                 strcpy(name, "GSD");
  17.                 cout << "CA(const CA &)"<< m_i << endl;
  18.         }

  19.         CA(CA &&oth):name(oth.name)
  20.         {
  21.                 oth.name = nullptr;
  22.                 cout << "CA(CA &&)" << m_i << endl;
  23.         }

  24.        
  25.         ~CA()
  26.         {
  27.                 delete[] name;
  28.                 cout << "~CA()"  << m_i << endl;
  29.         }
  30. private:
  31.          int m_i = ++g;
  32.          char *name;
  33. };


  34. CA p()
  35. {
  36.         CA a;
  37.         return a;
  38. }

  39. int main(void)
  40. {
  41.         CA a(p());
  42.         system("pause");
  43.     return 0;
  44. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-24 02:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表