[C++11]右值和右值引用

Posted Wecccccccc

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[C++11]右值和右值引用相关的知识,希望对你有一定的参考价值。

在这里插入图片描述

代码如下:

#include <iostream>
using namespace std;

int main()
{
	//左值
	int num = 9;
	//左值引用
	int &a = num;
	//右值
	const int N = 5;
	//右值引用
	int && b = 8;
	//常量左值引用
	const int &c = num;
	//常量右值引用
	const int &&d = 6;

	 //const int &&d = b; error
	//int && f = b; error

	//右值引用给常量的左值引用初始化
	const int &a = b;
	//常量右值引用给常量的右值引用初始化
	const int &aa = d;


}

右值引用的作用以及使用:

在这里插入图片描述

代码如下:

#include <iostream>
using namespace std;

class Test
{
public:
	Test() :m_num(new int(100))
	{
		cout << "construct" << endl;
		cout << "address = " << m_num << endl;
	}

	Test(const Test & a) :m_num(new int(*a.m_num))
	{
		cout << "copy construct" << endl;
	}

	~Test()
	{
		cout << "destruct" << endl;
		delete m_num;
	}

public:
	int *m_num;
};

Test getobj()
{
	Test t;
	return t;
}


int main()
{
	Test t = getobj();
	return 0;
}

测试结果:
在这里插入图片描述

代码如下:

#include <iostream>
using namespace std;

class Test
{
public:
	Test() :m_num(new int(100))
	{
		cout << "construct" << endl;
		cout << "address = " << m_num << endl;
	}

	Test(const Test & a) :m_num(new int(*a.m_num))
	{
		cout << "copy construct" << endl;
	}

	//有右值引用的构造函数称为移动构造函数
	//移动构造函数 -> 复用其他对象中的资源(堆内存)
	//m_num 浅拷贝
	Test(Test && a) :m_num(a.m_num)
	{
		a.m_num = nullptr;
		cout << "move construct" << endl;
	}

	~Test()
	{
		cout << "destruct" << endl;
		delete m_num;
	}

public:
	int *m_num;
};

Test getobj()
{
	Test t;
	return t;
}


int main()
{
	Test t = getobj();//直接赋值
	return 0;
}

测试结果:

在这里插入图片描述

因为getobj()返回的是临时变量,所以程序优先调用移动构造函数,如果返回的不是临时对象,就会调用拷贝构造函数。

通过右值引用赋值:

代码如下:

int main()
{
	Test && t1 = getobj();
	cout <<"address = "<< t1.m_num << endl;
	return 0;
}

测试结果:

在这里插入图片描述

不管是直接进行赋值,还是右值引用赋值,都要求右侧的对象是一个临时对象,才会调用移动构造函数。

如果没有移动构造函数,它会调用拷贝构造函数。

如果没有移动构造函数,使用右值引用初始化要求更高一点。

要求右侧是一个临时的不能取地址的对象。

代码如下:

Test getobj()
{
	return Test();
}


int main()
{
	Test && t2 = getobj();
	cout <<"address = "<< t2.m_num << endl;
	return 0;
}

测试结果:

在这里插入图片描述

在这里插入图片描述

代码如下:

Test&& getobj()//将亡值
{
	return Test();
}


int main()
{
	Test && t2 = getobj();
	cout <<"address = "<< t2.m_num << endl;
	return 0;
}

测试结果:

在这里插入图片描述

&&的特性:

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
右值引用被推导或被传递之后对应的就是一个左值或者右值。

以上图片来自下面链接:

https://subingwen.cn/cpp/rvalue-reference/

以上是关于[C++11]右值和右值引用的主要内容,如果未能解决你的问题,请参考以下文章

C++11——右值引用

[c++11]右值引用移动语义和完美转发

何时重载按引用传递(左值和右值)优于按值传递?

左值和右值

[转][c++11]我理解的右值引用移动语义和完美转发

c++中的左值和右值,右值引用到底是啥?关于引用这一节看得很迷糊。