C++11中引入了右值引用的概念 这里不再解释什么是右值引用,用一个例子说明右值引用对代码带的一些简化效果 下面是将一个方法分为两个版本,第一个方法中newNode使用右值引用参数newNode,第二个则是左值引用的
/* 右值引用版本 */
HashNode& insertNode(HashNode&& newNode) {
//do something
}
/* 左值引用版本 */
HashNode& insertNode(HashNode& newNode) {
return insertNode(std::move(newNode));//将newNode转为右值引用参数,调用右值引用版本的函数
}
以下是正常的左值引用调用
HashNode node{1,2};
insertNode(node);//调用左值引用版本的参数;
如果node只是个临时临时对象,并不需要保存给后面的代码使用,在没有右值引用版本的情况下,只能按上面的方式调用
因为我们定义了右值引用版本的insertNode
函数,所以就可以如下调用。不用再定义一个临时对象node
insertNode(HashNode {1,2});//如果没有右值引用版本,编译会报错。
更进一步,还可以这样简写,连类名都省略了:
insertNode({1,2});//如果没有右值引用版本,编译会报错。
如果觉得分别写两个引用版本的函数太麻烦,可以删除最前面代码中左值引用版本的函数,只保留右值引用的版本。
那么,在用左值引用调用时要用std::move
转为右值引用,例子如下:
HashNode node{1,2};
insertNode(std::move(node));//std::move将 node转为右值引用