C++11 move 语义
2015-08-15 16:26
295 查看
首先认识3种拷贝构造函数:
1.默认的拷贝构造函数;
2.自己定义的拷贝构造函数;
3.move拷贝构造函数;
对于这么个结构体
默认的构造函数,就会依次对应赋值,这样就会出现一个问题,如果给起赋值的是一个临时变量 MyTest t = temp,那么,表达式结束以后,temp.d释放掉,t.d就会成为野指针不安全。
然后,自定义的拷贝构造函数,就是所谓的深层拷贝,为t.d申请同样大小的内存,然后依次赋值
最后就是到了 move 构造了,首先他会辨认出,给他赋值的是一个临时变量,他的效果咧,就是避免这样的拷贝浪费时间,能避免赋值和内存申请
通过这样,就窃取到临时变量的数据,又避免了野指针和内存申请,数据拷贝。
1.默认的拷贝构造函数;
2.自己定义的拷贝构造函数;
3.move拷贝构造函数;
typedef struct MyTest{ int a; int b; float c; int * d; MyTest ():a(1),b(2),c(2.2){ d = new int[10]; for(int i = 0;i<10;i++){ d[i] = i; } } ~MyTest(){ delete []d; } }MyTest;
对于这么个结构体
默认的构造函数,就会依次对应赋值,这样就会出现一个问题,如果给起赋值的是一个临时变量 MyTest t = temp,那么,表达式结束以后,temp.d释放掉,t.d就会成为野指针不安全。
然后,自定义的拷贝构造函数,就是所谓的深层拷贝,为t.d申请同样大小的内存,然后依次赋值
MyTest(MyTest& t){ a = t.a; b = t.b; c = t.c; d = new int[10]; for (int i = 0;i<10;i++){ d[i] = t.d[i]; } }
最后就是到了 move 构造了,首先他会辨认出,给他赋值的是一个临时变量,他的效果咧,就是避免这样的拷贝浪费时间,能避免赋值和内存申请
MyTest(MyTest&& t){ a = t.a; b = t.b; c = t.c; d = t.d; t.d = NULL; }
通过这样,就窃取到临时变量的数据,又避免了野指针和内存申请,数据拷贝。
相关文章推荐
- c++连接数据库的头文件设置
- C/C++混合编程出现:预编译头文件来自编译器的早期版本,或者预编译头为 C++ 而在 C 中使用它(或相反)问题的解决方案
- (转载)在C++程序中使用pbrt进行渲染
- protobuf 一个c++示例
- C语言数组初始化全部为0
- Codeforces Round #283(Div.2) A,B,C,D,E 解题报告
- [C++11 并发编程] 07 - Mutex 死锁
- C/C++ 中struct嵌套的内存分配
- C++ Primer Plus 第6版 中文版 第4章编程练习
- Visual C++开发工具与调试技巧整理
- C++泛型编程思想方法总结
- C语言中关于 赋值语句X=Y的解析
- win8.1 和VC++ 6.0的兼容问题解决
- C语言学习笔记——基本语法
- 迭代器,数组和指针瞎扯扯
- C++基础---枚举
- 创建堆,堆排序的详细实现过程,C++完整代码
- C++基础---空类型
- C++基础---布尔型
- UTF-8 CPP的使用