提示:本文是对于右值引用&移动语义&移动构造函数三者的介绍
目录
前言
随着对类的深入学习,会逐渐了解到空类的几个默认函数,其中有一个是移动构造函数,算是这里面比较复杂的了。自己在学习过程之中也是有些模糊,这方面的文章不够深入详细,了解后想总结一篇文章,接下来我会详细介绍它。
一、移动构造函数是什么?
从名字上来说,它肯定是一个构造函数。构造函数的作用就是为了构造一个类对象。举例默认构造函数,会在没有显式提供初始化时调用。
复制构造函数会在:类对象作为形参, 函数返回值, 以及用已经存在的对象赋值生成一个新的对象时调用。而移动构造函数的调用时机呢?如果入参为临时对象来初始化类的对象时,则会调用移动构造函数。临时对象属于右值,右值就是那些无法取到地址的值。所以移动构造函数的形参为右值引用。引用作为入参可以避免以值来传参,减少拷贝。
所以当以左值引用作为形参的时候是拷贝构造函数,以右值引用作为形参的时候是移动构造函数(一般一些临时对象,数值都属于右值)。这样类就会知道什么时候使用拷贝构造函数,什么时候使用移动构造函数。
二、代码案例
代码如下:
#include <iostream>
using namespace std;
class demo{
public:
// 默认构造函数
demo():num(new int(0)){
cout<<"construct!"<<endl;
}
// 拷贝构造函数
demo(const demo &d):num(new int(*d.num)){
cout<<"copy construct!"<<endl;
}
//添加移动构造函数
demo(demo &&d):num(d.num){ // 移动构造函数需要以右值引用作为形参,而右值引用使用两个 &表示
d.num = nullptr; // num(d.num)已经指向原来的int,这里对于原来的指针变量需要它指向nullptr。这样析构时候才不会出现问题
cout<<"move construct!"<<endl;
}
~demo(){
cout<<"class destruct!"<<endl;
}
private:
int *num;
};
demo get_demo(){
return demo(); // 返回的是临时对象,临时对象属于右值
}
int main(){
demo a = get_demo(); // 右边函数返回的是右值,所以对于左边的demo a会使用移动构造函数来进行实例化
return 0;
}
总结
本文仅仅简单介绍了移动构造函数,对于一些过于细节的地方还有为表达清楚地方,如有疑问,欢迎评论,大家一起解决问题。