qq1242009750 发表于 2018-2-9 15:07:15

C++11 移动构造函数

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

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

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


那我们普通的构造函数呢

从图上可以看出,相当于复制了一个副本。

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

将亡值就是通过函数返回的值,也可以是一个匿名变量(没有名字的变量)。
例如:
CA p()
{
        CA a;
        return a;
}
此函数会返回一个将亡值。

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

好,我们知道了如何定义移动构造函数了,那么我们该怎样写他的内容呢?
首先我们定义一个类
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;
                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;
                strcpy(name, "GSD");
                cout << "CA()" << m_i << endl;
        }


        CA(const CA &oth)
        {
                name = new char;
                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;
}
页: [1]
查看完整版本: C++11 移动构造函数