/*##################################################################
* 右值引用 (C++ 11)
* 主要用于以下:
* 1. 移动语义
* 2. 完美传参 Perfect Forwarding
*/ /*
* 什么是右值引用?
*/ int a = 5;
int& b = a; // b是左值引用,在C++ 03叫做引用 int&& c // c 右值引用 void printInt(int& i) { cout << "lvalue reference: " << i << endl; }
void printInt(int&& i) { cout << "rvalue reference: " << i << endl; } int main() {
int i = 1;
printInt(i); // 调用第1个printInt
printInt(6); // 调用第2个printInt printInt(std::move(i)); // i是左值,先调move(),再调第2个printInt
} /*
* 函数签名:
*
* int和int&不区分
* int和int&&不区分
*
* int&和int&&区分,也就是可以重载左值引用和右值引用两个
*/ /* What's the big deal??? */ class boVector {
int size;
string label;
double* array;
public:
boVector(const boVector& rhs) { // 拷贝构造
size = rhs.size;
array = new double[size];
for (int i=0; i<size; i++) { array[i] = rhs.array[i]; }
}
// boVector(const boVector&& rhs) { // 移动构造
// size = rhs.size;
// array = rhs.array;
// rhs.array = nullptr;
// }
};
void foo_by_value(boVector v) { v.label = "Student's Ages"; } //如果没有右值引用,需要很多不同版本的函数
void foo_by_reference(boVector& v) { v.label = "Student's Ages"; }
boVector createBoVector(); // Creates a boVector void main() {
boVector reusable = createBoVector();
foo_by_value(reusable);
...
boVector tmp= createBoVector();
foo_by_reference(tmp);
} /* Notes:
boVector(const boVector&& rhs) { // 移动构造
size = rhs.size;
array = rhs.array;
} boVector reusable = createBoVector();
foo(reusable);
*/ // 练习:
boVecotor b = createBoVector(); // Approach 1:
void foo(boVector & v);
foo(b); // Approach 2:
void foo(boVector && v);
foo(std::move(b)); // 问题:两种方法的相同点和不同点
// 两者参数传递上都不需要深拷贝
// 后者将所有权也传递, move后不能再使用 /*
* Note 1: 右值引用最主要的使用地方是重载拷贝构造和拷贝赋值,得到移动语义
*/
X& X::operator=(X const & rhs);
X& X::operator=(X&& rhs); /* Note 2: 所以得STL容器都实现了移动语义,这意味着:
* a. 只要切换到C++ 11,代码不做任何改变程序就能变快
* b. 使用值传递的频率更高了
*/ vector<int> foo() { ...; return myvector; } //可以直接返回 void goo(vector<int>& arg); // 当需要使用参数将goo中处理之后的数据带回外面,需要用引用传递 /* 移动构造:
* 目的:避免不必要的深拷贝
* 1. 当既需要传引用又需要传值得时候,移动构造很有用
* 2. 移动构造允许你对移动对象那个部分进行细微的控制
*/ // 陷阱:右值引用是一个右值么? boVector(const boVector && rhs) {
cout << "Move constructor.\n";
size = rhs.size;
array = rhs.array;
overload(rhs);
} overload(boVector& v) { cout << "by lvalue."; }
overload(boVector&& v) { cout << "by rvalue."; }

C++11--右值引用(移动语义)的更多相关文章

  1. 关于C++11右值引用和移动语义的探究

    关于C++11右值引用和移动语义的探究

  2. C++11右值引用

    [C++11右值引用] 1.什么是左值?什么是右值? 左值是表达式结束后依然存在的对象:右值是表达式结束时就不再存在的对象. 2.std::move的作用是什么? std::move用于把任意类型转化 ...

  3. C++11 右值引用和转移语义

    新特性的目的 右值引用 (Rvalue Referene) 是 C++ 新标准 (C++11, 11 代表 2011 年 ) 中引入的新特性 , 它实现了转移语义 (Move Sementics) 和 ...

  4. C++11 右值引用 与 转移语义

    新特性的目的 右值引用(R-value Reference)是C++新标准(C++11, 11代表2011年)中引入的新特性,它实现了转移语义(Move Semantics)和精确传递(Perfect ...

  5. c++11 右值引用和移动语义

    什么是左值.右值 最常见的误解: 等号左边的就是左值,等号右边的就是右值 左值和右值都是针对表达式而言的, 左值是指表达式结束后依然存在的持久对象 右值是指表达式结束时就不再存在的临时对象区分: 能对 ...

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

    c++中引入了右值引用和移动语义,可以避免无谓的复制,提高程序性能.有点难理解,于是花时间整理一下自己的理解. 左值.右值 C++中所有的值都必然属于左值.右值二者之一.左值是指表达式结束后依然存在的 ...

  7. C++ 11 右值引用

    C++11中引入的一个非常重要的概念就是右值引用.理解右值引用是学习“移动语义”(move semantics)的基础.而要理解右值引用,就必须先区分左值与右值. 注意:左值右值翻译可能有些问题 *L ...

  8. C++ 11 右值引用以及std::move

    转载请注明出处:http://blog.csdn.net/luotuo44/article/details/46779063 新类型: int和int&是什么?都是类型.int是整数类型,in ...

  9. 【转】C++ 11 右值引用的理解

    右值引用的目的之一,是为了C++中一个比较影响性能的问题:拷贝临时对象,例如,在 int foo(){ ... } int x; x = foo(); 中,在第三句中,发生了以下的事情: 1.销毁 x ...

  10. C++11右值引用和std::move语句实例解析

    关键字:C++11,右值引用,rvalue,std::move,VS 2015 OS:Windows 10 右值引用(及其支持的Move语意和完美转发)是C++0x将要加入的最重大语言特性之一.从实践 ...

随机推荐

  1. 九度OJ1049题-去特定字符(和1111题特别像)

    题目1049:字符串去特定字符 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:11329 解决:5169 题目描述: 输入字符串s和字符c,要求去掉s中所有的c字符,并输出结果. 输入: ...

  2. python学习之路02

    1.python的数据类型有:Number String List Truple Sets Dictionary . 数字类型:int float bool complex 2.不可变数据:数字 字符 ...

  3. 2017-2018-1 20155208 课堂测试(ch06)(补做)

    2017-2018-1 20155208 课堂测试(ch06)(补做) 1.( 多选题 | 1 分) 下面说法正确的是(ABC) A . 存储层次结构中最小的缓存是寄存器 B . 存储层次结构的中心思 ...

  4. python开发day02

    一 while循环 while 条件 代码块(循环体)  #:  判断条件是否为真,如果是真,则执行代码块, 然后再次回头判断条件是否为真,如果为真,则只执行代码块.......知道循环的判断出代码为 ...

  5. PTA——最大公约数和最小公倍数

    PTA 7-26 最大公约数和最小公倍数 #include<stdio.h> int main(){ int num1,num2,temp1,temp2,r; scanf("%d ...

  6. Hive错误:Error: FUNCTION 'NUCLEUS_ASCII' already exists. (state=X0Y68,code=30000)

    问题 初始化derby失败: [root@bigdata111 apache-hive-2.3.0-bin]# schematool -dbType derby -initSchemaSLF4J: C ...

  7. centos7虚拟机安装elasticsearch5.0.x-安装篇

    https://blog.csdn.net/u012371450/article/details/51776505 请预先安装jdk 创建新用户(非root用户)elasticsearch只能用非ro ...

  8. MVVM在WPF中应用(1)

    在软件行业浸润了这么多年,第一次在MES的工厂里从事软件开发. 在这里的感觉就是安静.宽松,比在那些专门以软件为主的企业中轻松自在.在这里的第一个项目是关于数据的导入和导出,还有数据的比较这些功能. ...

  9. Map接口的使用

    1.Map定义: Collection是孤立存在的,向集合中存储元素是一个一个放,Map中的集合 存储是成对,通过键找到值,键和值是映射关系. 2.注意: Map集合中不能包含重复的键,但是可以包含重 ...

  10. mysqldump命令之single-transaction

    =========================================================在mysqldump中指定single-transaction时,会使用可重复读(RE ...