c项目实战 cboost线程命名


c项目实战 cboost线程命名


【c项目实战 cboost线程命名】
I、保持语言的稳定性和兼容性” 总结:主要是utf8字符串 , 虚函数override/final支持 。1、c11宏和类型(考虑和c99兼容):STDC_HOSTED、STDC、__VA_ARGS__宏可以替代…、__cplusplus宏用于c和c混编 , 非布尔值还可以判断是否支持c11;_Pragma操作符 。long long 64bit类型, static_assert用于编译时警告,表达式必须是常量 。string都是utf-8类型的 , 可以和utf-16 , char*等转换 。可用sizeof(类::非静态成员)获取成员大小 。2、面向对象语言特性完善:虚函数override/final支持;增加非静态成员变量就地初始化=和{}符号;noexcept函数声明没有异常抛出 , 如果抛出了则用std::terminate()来终止程序; 3、完善拓展模板语法:friend FriendClass就可以声明友元 , 模板中也可使用;模板函数也支持了默认参数;显式模板实例化和外部模板声明优化链接;匿名和局部的类/结构体等 , 都可以作为模板实参 。
II、“通用为本 , 专用为末” 总结:主要是右值引用 , 移动语义 , 完美转发的引入 。1、对性能的更加关注 , 和C高效兼容:引入右值引用类型 , 函数模板完美转发实现;和C语言的兼容 , pod类型的定义;联合体的拓展 。2、面向对象编写要更加高效和简单:移动构造函数 , 移动语义;继承构造函数和构造函数委派; explict拓展到类型转换函数;类型初始化列表的支持 。3、完善拓展泛型编程语法:inline名字空间允许父空间中对模板重定义;using别名可以用于模板和实例化模板;实例化模板时对SFINAE原则拓展 , 允许模板参数中存在非实例化的表达式存在 。
III、“易学易用” 总结:主要是是类型推导规则引入 , for自动范围和迭代引入 。1、基础符号编译器增强:1).>>避免模板或类型转换中需添加额外的空格 。2).for(auto &e: containerObj){}自动范围和迭代语句,数组和STL容器都支持(stl中e是元素类型) , 自定义容器需重载 。2、新增了类型推导规则: 1).auto编译期类型多用于函数或表达式内部的变量 , 不能用于函数参数 , 类成员 , 数组和模板实例化中(虽然提供值) , 可以用于初始化列表和new对象中 。会去掉volatile和const修饰符 。2).decltype是最灵活的编译期类型 , 根据表达式而不是只推导类型 , 可以用在所有表达式类型确定的地方(函数返回值是不确定的) , 可以带走volatile和const修饰符 。左值判断技巧 。auto可以减少代码量 , decltype可以更灵活的获得表达式运算后的类型 , 他们都有类型自适应性(值修改后类型不用变),可以多用于库相关代码的编写 。业务逻辑用确定类型会清晰些 。3、追踪返回类型 , auto和decltype的结合 , auto Sum(T1 &t1, T2 &t2) -> decltype(t1 t2) { return t1 t2}能确定运算后变化的类型 , 增强函数和函数指针泛型能力 。
IV 、“提高类型安全” 总结: 1、新枚举类型:新增了enum class enumName:type{}作用域限定符和类型 。2、智能指针:unique_ptr用在单模块内使用 , shared_ptr和weak_ptr用引用计数在多个模块间共享 。记得初始化;判是否有效 , *和->使用 , 需转换为原指针迭代跳转;move或reset后要小心使用 。3、GC: 标记-清除GC实现 , 现在暂时定义了接口 , 原因是指针的太灵活(指针任意在内存中跳转)导致隐藏指针 , GC会误删 , 用declare_reachable等标记隐藏指针解决 , 且delete和回收是兼容的 。
V、”提高性能及其操作硬件的能力“ 总结: 1、1)constexpr是编译期常量 , constexpr元编程的引入;2)变长参数模板类和函数模板 , 库编写用简单实例思维解决 , 非库编写者用tuple和容器的emplace系列函数即可 。元编程对库程序员是一种简化 , 而不是复杂化 。2、并行编程: 1)原子类型:atomic定义基本类型 , 自定义类型用_Atomic实现(现在还不支持) , 原子类型是编译器用了系统底层的总线锁或存储锁加快锁定 , 其它同时访问线程会被阻塞 , atomic_flag自旋无锁同步 , memory_order对弱顺序代码执行内存模型调优 , 是cpp11并行编程中的一大亮点 。2).多线程库引入:cpp11内置的线程其实是封装了pthread线程 , 使用更加简单 , 但是没有pthread底层和控制能力强 。3).TLS变量 , 对全局静态常量数据和线程生命期绑定 , 关键字是thread_local 。cpp11 errno变量是线程局部的而不是全局的 。3、进程退出:用quick_exit需要退出回调的用at_quick_exit(目前LLVM还没实现);异常退出还是要terminate实现 。

推荐阅读