马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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;
}
|