注重体验与质量的电子书资源下载网站
分类于: 互联网 人工智能
简介
深入理解C++11: C++ 11新特性解析与应用 豆 7.7分
资源最后更新于 2020-09-04 14:47:28
作者:Michael Wong
出版社:机械工业出版社
出版日期:2013-01
ISBN:9787111426608
文件格式: pdf
标签: C++ C++11 C/C++ 编程 计算机 程序设计 编程语言 新标准
简介· · · · · ·
《深入理解C++11:C++11新特性解析与应用》内容简介:国内首本全面深入解读C++11新标准的专著,由C++标准委员会代表和IBM XL编译器中国开发团队共同撰写。不仅详细阐述了C++11标准的设计原则,而且系统地讲解了C++11新标准中的所有新语言特性、新标准库特性、对原有特性的改进,以及如何应用所有这些新特性。
《深入理解C++11:C++11新特性解析与应用》一共8章:第1章从设计思维和应用范畴两个维度对C++11新标准中的所有特性进行了分类,呈现了C++11新特性的原貌;第2章讲解了在保证与C语言和旧版C++标准充分兼容的原则下增加的一些新特性;第3章讲解了具有广泛可用性、能与其他已有的或者新增的特性结合起来使用的、具有普适性的一些新特性;第4章讲解了C++11新标准对原有一些语言特性的改进,这些特性不仅能让C++变得更强大,还能提升程序...
目录
免责声明
序
前言
第1章 新标准的诞生
1.1 曙光:c++11标准的诞生
1.1.1 c++11/c++0x(以及c11/c1x)—新标准诞生
1.1.2 什么是c++11/c++0x
1.1.3 新c++语言的设计目标
1.2 今时今日的c++
1.2.1 c++的江湖地位
1.2.2 c++11语言变化的领域
1.3 c++11特性的分类
1.4 c++特性一览
1.4.1 稳定性与兼容性之间的抉择
1.4.2 更倾向于使用库而不是扩展语言来实现特性
1.4.3 更倾向于通用的而不是特殊的手段来实现特性
1.4.4 专家新手一概支持
1.4.5 增强类型的安全性
1.4.6 与硬件紧密合作
1.4.7 开发能够改变人们思维方式的特性
1.4.8 融入编程现实
1.5 本书的约定
1.5.1 关于一些术语的翻译
1.5.2 关于代码中的注释
1.5.3 关于本书中的代码示例与实验平台
第2章 保证稳定性和兼容性
2.1 保持与c99兼容
2.1.1 预定义宏
2.1.2 __func__预定义标识符
2.1.3 _pragma操作符
2.1.4 变长参数的宏定义以及__va_args__
2.1.5 宽窄字符串的连接
2.2 long long整型
2.3 扩展的整型
2.4 宏__cplusplus
2.5 静态断言
2.5.1 断言:运行时与预处理时
2.5.2 静态断言与static_assert
2.6 noexcept修饰符与noexcept操作符
2.7 快速初始化成员变量
2.8 非静态成员的sizeof
2.9 扩展的friend语法
2.10 final/override控制
2.11 模板函数的默认模板参数
2.12 外部模板
2.12.1 为什么需要外部模板
2.12.2 显式的实例化与外部模板的声明
2.13 局部和匿名类型作模板实参
2.14 本章小结
第3章 通用为本,专用为末
3.1 继承构造函数
3.2 委派构造函数
3.3 右值引用:移动语义和完美转发
3.3.1 指针成员与拷贝构造
3.3.2 移动语义
3.3.3 左值、右值与右值引用
3.3.4 std::move:强制转化为右值
3.3.5 移动语义的一些其他问题
3.3.6 完美转发
3.4 显式转换操作符
3.5 列表初始化
3.5.1 初始化列表
3.5.2 防止类型收窄
3.6 pod类型
3.7 非受限联合体
3.8 用户自定义字面量
3.9 内联名字空间
3.10 模板的别名
3.11 一般化的sfinea规则
3.12 本章小结
第4章 新手易学,老兵易用
4.1 右尖括号>的改进
4.2 auto类型推导
4.2.1 静态类型、动态类型与类型推导
4.2.2 auto的优势
4.2.3 auto的使用细则
4.3 decltype
4.3.1 typeid与decltype
4.3.2 decltype的应用
4.3.3 decltype推导四规则
4.3.4 cv限制符的继承与冗余的符号
4.4 追踪返回类型
4.4.1 追踪返回类型的引入
4.4.2 使用追踪返回类型的函数
4.5 基于范围的for循环
4.6 本章小结
第5章 提高类型安全
5.1 强类型枚举
5.1.1 枚举:分门别类与数值的名字
5.1.2 有缺陷的枚举类型
5.1.3 强类型枚举以及c++11对原有枚举类型的扩展
5.2 堆内存管理:智能指针与垃圾回收
5.2.1 显式内存管理
5.2.2 c++11的智能指针
5.2.3 垃圾回收的分类
5.2.4 c++与垃圾回收
5.2.5 c++11与最小垃圾回收支持
5.2.6 垃圾回收的兼容性
5.3 本章小结
第6章 提高性能及操作硬件的能力
6.1 常量表达式
6.1.1 运行时常量性与编译时常量性
6.1.2 常量表达式函数
6.1.3 常量表达式值
6.1.4 常量表达式的其他应用
6.2 变长模板
6.2.1 变长函数和变长的模板参数
6.2.2 变长模板:模板参数包和函数参数包
6.2.3 变长模板:进阶
6.3 原子类型与原子操作
6.3.1 并行编程、多线程与c++11
6.3.2 原子操作与c++11原子类型
6.3.3 内存模型,顺序一致性与memory_order
6.4 线程局部存储
6.5 快速退出:quick_exit与at_quick_exit
6.6 本章小结
第7章 为改变思考方式而改变
7.1 指针空值—nullptr
7.1.1 指针空值:从0到null,再到nullptr
7.1.2 nullptr和nullptr_t
7.1.3 一些关于nullptr规则的讨论
7.2 默认函数的控制
7.2.1 类与默认函数
7.2.2 “= default”与“= deleted”
7.3 lambda函数
7.3.1 lambda的一些历史
7.3.2 c++11中的lambda函数
7.3.3 lambda与仿函数
7.3.4 lambda的基础使用
7.3.5 关于lambda的一些问题及有趣的实验
7.3.6 lambda与stl
7.3.7 更多的一些关于lambda的讨论
7.4 本章小结
第8章 融入实际应用
8.1 对齐支持
8.1.1 数据对齐
8.1.2 c++11的alignof和alignas
8.2 通用属性
8.2.1 语言扩展到通用属性
8.2.2 c++11的通用属性
8.2.3 预定义的通用属性
8.3 unicode支持
8.3.1 字符集、编码和unicode
8.3.2 c++11中的unicode支持
8.3.3 关于unicode的库支持
8.4 原生字符串字面量
8.5 本章小结
附录a c++11对其他标准的不兼容项目
附录b 弃用的特性
附录c 编译器支持
附录d 相关资源
序
前言
第1章 新标准的诞生
1.1 曙光:c++11标准的诞生
1.1.1 c++11/c++0x(以及c11/c1x)—新标准诞生
1.1.2 什么是c++11/c++0x
1.1.3 新c++语言的设计目标
1.2 今时今日的c++
1.2.1 c++的江湖地位
1.2.2 c++11语言变化的领域
1.3 c++11特性的分类
1.4 c++特性一览
1.4.1 稳定性与兼容性之间的抉择
1.4.2 更倾向于使用库而不是扩展语言来实现特性
1.4.3 更倾向于通用的而不是特殊的手段来实现特性
1.4.4 专家新手一概支持
1.4.5 增强类型的安全性
1.4.6 与硬件紧密合作
1.4.7 开发能够改变人们思维方式的特性
1.4.8 融入编程现实
1.5 本书的约定
1.5.1 关于一些术语的翻译
1.5.2 关于代码中的注释
1.5.3 关于本书中的代码示例与实验平台
第2章 保证稳定性和兼容性
2.1 保持与c99兼容
2.1.1 预定义宏
2.1.2 __func__预定义标识符
2.1.3 _pragma操作符
2.1.4 变长参数的宏定义以及__va_args__
2.1.5 宽窄字符串的连接
2.2 long long整型
2.3 扩展的整型
2.4 宏__cplusplus
2.5 静态断言
2.5.1 断言:运行时与预处理时
2.5.2 静态断言与static_assert
2.6 noexcept修饰符与noexcept操作符
2.7 快速初始化成员变量
2.8 非静态成员的sizeof
2.9 扩展的friend语法
2.10 final/override控制
2.11 模板函数的默认模板参数
2.12 外部模板
2.12.1 为什么需要外部模板
2.12.2 显式的实例化与外部模板的声明
2.13 局部和匿名类型作模板实参
2.14 本章小结
第3章 通用为本,专用为末
3.1 继承构造函数
3.2 委派构造函数
3.3 右值引用:移动语义和完美转发
3.3.1 指针成员与拷贝构造
3.3.2 移动语义
3.3.3 左值、右值与右值引用
3.3.4 std::move:强制转化为右值
3.3.5 移动语义的一些其他问题
3.3.6 完美转发
3.4 显式转换操作符
3.5 列表初始化
3.5.1 初始化列表
3.5.2 防止类型收窄
3.6 pod类型
3.7 非受限联合体
3.8 用户自定义字面量
3.9 内联名字空间
3.10 模板的别名
3.11 一般化的sfinea规则
3.12 本章小结
第4章 新手易学,老兵易用
4.1 右尖括号>的改进
4.2 auto类型推导
4.2.1 静态类型、动态类型与类型推导
4.2.2 auto的优势
4.2.3 auto的使用细则
4.3 decltype
4.3.1 typeid与decltype
4.3.2 decltype的应用
4.3.3 decltype推导四规则
4.3.4 cv限制符的继承与冗余的符号
4.4 追踪返回类型
4.4.1 追踪返回类型的引入
4.4.2 使用追踪返回类型的函数
4.5 基于范围的for循环
4.6 本章小结
第5章 提高类型安全
5.1 强类型枚举
5.1.1 枚举:分门别类与数值的名字
5.1.2 有缺陷的枚举类型
5.1.3 强类型枚举以及c++11对原有枚举类型的扩展
5.2 堆内存管理:智能指针与垃圾回收
5.2.1 显式内存管理
5.2.2 c++11的智能指针
5.2.3 垃圾回收的分类
5.2.4 c++与垃圾回收
5.2.5 c++11与最小垃圾回收支持
5.2.6 垃圾回收的兼容性
5.3 本章小结
第6章 提高性能及操作硬件的能力
6.1 常量表达式
6.1.1 运行时常量性与编译时常量性
6.1.2 常量表达式函数
6.1.3 常量表达式值
6.1.4 常量表达式的其他应用
6.2 变长模板
6.2.1 变长函数和变长的模板参数
6.2.2 变长模板:模板参数包和函数参数包
6.2.3 变长模板:进阶
6.3 原子类型与原子操作
6.3.1 并行编程、多线程与c++11
6.3.2 原子操作与c++11原子类型
6.3.3 内存模型,顺序一致性与memory_order
6.4 线程局部存储
6.5 快速退出:quick_exit与at_quick_exit
6.6 本章小结
第7章 为改变思考方式而改变
7.1 指针空值—nullptr
7.1.1 指针空值:从0到null,再到nullptr
7.1.2 nullptr和nullptr_t
7.1.3 一些关于nullptr规则的讨论
7.2 默认函数的控制
7.2.1 类与默认函数
7.2.2 “= default”与“= deleted”
7.3 lambda函数
7.3.1 lambda的一些历史
7.3.2 c++11中的lambda函数
7.3.3 lambda与仿函数
7.3.4 lambda的基础使用
7.3.5 关于lambda的一些问题及有趣的实验
7.3.6 lambda与stl
7.3.7 更多的一些关于lambda的讨论
7.4 本章小结
第8章 融入实际应用
8.1 对齐支持
8.1.1 数据对齐
8.1.2 c++11的alignof和alignas
8.2 通用属性
8.2.1 语言扩展到通用属性
8.2.2 c++11的通用属性
8.2.3 预定义的通用属性
8.3 unicode支持
8.3.1 字符集、编码和unicode
8.3.2 c++11中的unicode支持
8.3.3 关于unicode的库支持
8.4 原生字符串字面量
8.5 本章小结
附录a c++11对其他标准的不兼容项目
附录b 弃用的特性
附录c 编译器支持
附录d 相关资源