C++ 11 之学习总结
感慨时间过的好快,C++ 11出来都5年了,现在才开始学习,但为时也不晚;
主要是网上及身边的朋友大肆宣扬C++ 11的某些优化,弄得别人心里痒痒的,所以就花了3天学习了点基本知识,相对于整个C++ 11的新增来说就是九牛一毛;
先上一张C++ 11的图:
1.推导关键词 auto & decltype;
详解:http://www.cnblogs.com/viscount/p/5842872.html
2.Lambda的使用;
详解:http://www.cnblogs.com/viscount/p/5842805.html
3.统一初始化的语法;
详解:http://www.cnblogs.com/viscount/p/5842916.html
4.Delete和Default函数
.简介 我们知道C++的编译器在你没有定义某些成员函数的时候会给你的类自动生成这些函数,比如,构造函数,拷贝构造,析构函数,赋值函数。有些时候,我们不想要这些函数,比如,构造函数,因为我们想做实现单例模式。传统的做法是将其声明成private类型。 在新的C++中引入了两个指示符,delete意为告诉编译器不自动产生这个函数,default告诉编译器产生一个默认的 .例子 Default: structA { A()=default; //C++11 virtual~A()=default; //C++11 }; Delete: structNoCopy { NoCopy & operator =( constNoCopy & ) = delete; NoCopy ( constNoCopy & ) = delete; }; NoCopy a; NoCopy b(a); //compilation error, copy ctor is deleted 解析:default看起来貌似毫无用处,本来就会默认构造,但如果有定义构造,编译器就不会默认构造,这时候你用到default就是让默认构造和自定义构造共存;如下: structSomeType { SomeType() = default; // 使用编译器生成的默认构造函数 SomeType(OtherType value); }; .Delete两个有用点: a.让对象只能生成在栈内存上; structNonNewable { void*operator new(std::size_t) = delete; }; b.阻止函数的形参类型的调用;(若尝试以 double 的形参调用 f(),将会引发编译期错误, 编译器不会自动将 double 形参转型为 int 再调用f()) voidf(inti); voidf(double) = delete;
5.nullptr 和委托构造函数
.题外话 C/C++的NULL宏是个被有很多潜在BUG的宏。因为有的库把其定义成整数0,有的定义成 (。在C的时代还好。但是在C++的时代,这就会引发很多问题 .nullptr 是强类型的。 voidf(int); //#1 voidf(char*);//#2 //C++03 f(); //二义性 //C++11 f(nullptr) //无二义性,调用f(char*) .所有和指针相关的地方都用nullptr,包括函数指针和成员指针; const char *pc=str.c_str(); //data pointers if (pc!=nullptr) cout<<pc<<endl; int (A::*pmf)()=nullptr; //指向成员函数的指针 void (*pmf)()=nullptr; //指向函数的指针 --------------委托构造函数-------------- .题外话 在以前的C++中,构造函数之间不能互相调用,所以,我们在写这些相似的构造函数里,我们会把相同的代码放到一个私有的成员函数中 .定义: C++ 中构造函数可以调用同一个类的另一个构造函数: .例子 class M //C++11 delegating constructors { int x, y; char *p; public: M(), p(new char [MAX]) {} //#1 target M(): M() {cout<<"delegating ctor"<<end;} //#2 delegating 解析:# 就是所谓的委托构造函数,调用了真正的构造函数 #。
6.右值引用和move语意
.目的 a.消除两个对象交互时不必要的对象拷贝,节省运算存储资源,提高效率; b.能够更简洁明确的定义泛型函数; .左值的声明符号为“&”,为了和左值区分,右值声明符为“&&”; 例子: void process_value(int& i) { std::cout << "LValue processed: " << i << std::endl; } void process_value(int&& i) { std::cout << "RValue processed: " << i << std::endl; } int main() { ; process_value(a); //输出Lvalue 0; process_value(); //输出Rvalue 1 } .但是如果临时对象通过一个接受右值的函数传递给另一个函数时,就会变成左值,因为这个临时对象在传递过程中,变成了命名对象。 void process_value(int& i) { std::cout << "LValue processed: " << i << std::endl; } void process_value(int&& i) { std::cout << "RValue processed: " << i << std::endl; } void forward_value(int&& i) { process_value(i); } int main() { ; process_value(a); //Lvalue 0 process_value(); //Rvalue 1 forward_value(); //Lvalue 2 }
7.Override和final
.解释; Override:表示派生类应当重写这个基类中的这个虚函数; Final: 表示派生类不应当重写这个虚函数; //Overrride例子 classB { public: virtualvoidf(int){std::cout<<"B::f"<<std::endl;} }; classD:publicB { public: virtualvoidf(int)override{std::cout<<"D::f"<<std::endl;} }; //Final例子 classB { public: virtualvoidf(int){std::cout<<"B::f"<<std::endl;} }; classD:publicB { public: virtualvoidf(int)overridefinal{std::cout<<"D::f"<<std::endl;} }; classF:publicD { public: virtualvoidf(int)override{std::cout<<"F::f"<<std::endl;} }; 报错,在类D中就已经声明不再重写这个虚函数
8.区间迭代
.意义:所有语言都有一种对一个区间写for循环的便捷方式; 例子: vector<, , , , }; for (auto i:vec) { cout << i << endl; }
C++ 11 之学习总结的更多相关文章
- 201521123082 《Java程序设计》第11周学习总结
201521123082 <Java程序设计>第11周学习总结 标签(空格分隔):java 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. Answe ...
- 201521123067 《Java程序设计》第11周学习总结
201521123067 <Java程序设计>第11周学习总结 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2. 书面作业 本次PTA作业题集多线 ...
- 201521123045 <java程序设计>第11周学习总结
201521123045 <java程序设计>第11周学习总结 1. 本周学习总结 2. 书面作业 2. 书面作业 Q1.1.互斥访问与同步访问完成题集4-4(互斥访问)与4-5(同步访问 ...
- 2018面向对象程序设计(Java)第11周学习指导及要求
2018面向对象程序设计(Java)第11周学习指导及要求 (2018.11.8-2018.11.11) 学习目标 (1) 掌握Vetor.Stack.Hashtable三个类的用途及常用API: ...
- 20172333 2017-2018-2 《Java程序设计》第11周学习总结
20172333 2017-2018-2 <Java程序设计>第11周学习总结 教材学习内容 对于Android Studio的安装以及对安卓的一些基本组成,比如说四大组件Acticity ...
- 20145202马超 2016-2017-2 《Java程序设计》第11周学习总结
20145202马超 2016-2017-2 <Java程序设计>第11周学习总结 教材学习内容总结 XX 教材学习中的问题和解决过程 教材学习有问题先去https://shimo.im/ ...
- C++11并发学习之三:线程同步(转载)
C++11并发学习之三:线程同步 1.<mutex> 头文件介绍 Mutex又称互斥量,C++ 11中与 Mutex 相关的类(包括锁类型)和函数都声明在 <mutex> 头文 ...
- 面向对象程序设计(JAVA) 第11周学习指导及要求
2019面向对象程序设计(Java)第11周学习指导及要求 (2019.11.8-2018.11.11) 学习目标 理解泛型概念: 掌握泛型类的定义与使用: 掌握泛型方法的声明与使用: 掌握泛型接 ...
- 20175316盛茂淞 2018-2019-2 《Java程序设计》第11周学习总结
20175316 <Java程序设计> 第11周学习总结 教材内容学习总结 第十三章 URL类 URL类是java.net包中的一个重要的类,URL的实例封装着一个统一资源定位符,使用UR ...
- 20175212童皓桢 《Java程序设计》第11周学习总结
20175212童皓桢 <Java程序设计>第11周学习总结 教材学习内容总结 一.URL类 1.一个URL对象通常包含最基本的三部分信息:协议.地址.资源 2.构造方法: public ...
随机推荐
- shell 编程中使用到得if语句内判断参数
http://blog.chinaunix.net/uid/21411227/cid-63616-list-1.html 1.判断文件类型 –b 当file存在并且是块文件时返回真 -c 当fil ...
- BIOS 深入学习 转
http://blog.csdn.net/lightseed/article/category/547391
- java字符串分解 StringTokenizer用法(比split()方法效率高)
Java中substring方法可以分解字符串,返回的是原字符串的一个子字符串.如果要讲一个字符串分解为一个一个的单词或者标记,StringTokenizer可以帮你. int countTokens ...
- jquery ui 改写cloes事件
htmlAjax:{//模板ajax请求参数设置项 url:"template/task/task_create.html", data ...
- Socket 之 API函数介绍
1.创建套接字──socket() 应用程序在使用套接字前,首先必须拥有一个套接字,系统调用socket()向应用程序提供创建套接字的手段,其调用格式如下: SOCKET PASCAL FAR soc ...
- mysql 查看表记录新增、修改的时间
ALTER TABLE `tableName` ADD `updateAt` TIMESTAMP NULL ON UPDATE CURRENT_TIMESTAMP; ALTER TABLE kd_up ...
- 【阿里云产品公测】弹性伸缩服务ESS之试用初体验
弹性伸缩服务ESS之试用初体验 作者:云郎 2014/10/15 阿里云弹性伸缩服务(Elastic Scaling Service)是根据用户的业务需求和策略,自动调整其弹性计算服务器(ECS)的管 ...
- (五)u-boot2013.01.01 for TQ210:《移植前的准备及u-boot初编译》
移植前的准备 移植前,要做的事情是搭建开发环境以及对U-boot源码的获取.首先说一下开发环境: 1.此次U-boot移植的硬件平台是天嵌的TQ210开发板: CPU:板载核心是S5PV210(Cor ...
- Read / Write Excel file in Java using Apache POI
Read / Write Excel file in Java using Apache POI 2014-04-18 BY DINESH LEAVE A COMMENT About a year o ...
- JQuery总结:选择器归纳、DOM遍历和事件处理、DOM完全操作和动画 (转)
JQuery总结:选择器归纳.DOM遍历和事件处理.DOM完全操作和动画 转至元数据结尾 我们后台可能用到的页面一般都是用jquery取值赋值的,发现一片不错的文章 目录 JQuery总结一:选择器归 ...