本文共 1627 字,大约阅读时间需要 5 分钟。
1、C++98中仅模板类支持默认参数,模板函数不支持默认参数,但C++11中模板类和模板函数均支持默认参数
2、模板类的默认参数,对C++98和C++11中,需遵循“从右往左”的规则指定。 3、模板函数的默认参数,则没有该限制在子类中使用该语法声明继承父类的哪些方法,而不必再写一遍沟通函数
using 父类::函数名;为了区分被调用者和调用者,称为初始化列表中调用“基准版本”的构造函数为委派构造函数(delegating constructor),而被调用的“基准版本”则为目标构造函数(target constructor)。在C++11中,所谓委派构造,就是指委派函数将构造的任务委派给了目标构造函数来完成这样一种类构造的方式。
个人总结: 1、类中的构造函数可以继承其它构造函数,并做扩展。看上去类似调用父类的构造函数。 2、抽象出最为“通用”的行为做目标构造函数。class Info {public: Info() { InitRest(); } Info(int i) : Info() { type = i; } Info(char e) : Info() { name = e; }private: void InitRest() { /* 其他初始化 */ } int type { 1}; char name { 'a'}; // ....};
C++11将POD划分为两个基本概念的合集,即:平凡的(trivial)和标准布局的(standard layout)
a、平凡的类或结构体符合以下定义: 1)拥有平凡的默认构造函数(trivial constructor)和析构函数(trivial destructor) 2)拥有平凡的拷贝构造函数(trivial copy constructor)和移动构造函数(trivial move constructor) 3)拥有平凡的靠背赋值运算符(trivial assignment operator)和移动赋值运算符(trivial move operator) 4)不能包含虚函数以及虚基类 //使用该辅助的类模板判断 template struct std::is_trivial;b、标准布局
1)所有非静态成员有相同的访问权限(public,private,protected) 2)在类或者结构体继承时,满足以下两种情况之一 a、派生类中有非静态成员,且只有一个仅包含静态成员的基类。 b、基类有非静态成员,而派生类没有非静态成员。 3)类中第一个非静态成员的类型与其基类不同。 4)没有虚函数和虚基类。 5)所有非静态数据成员均符合标准布局类型,其基类也符合标准布局。这是一个递归的定义。枚举值 | 定义规则 |
---|---|
memory_order_relaxed | 不对执行顺序做任何保证 |
memory_order_acquire | 本线程中,所有后续的读操作必须在本条原子操作完成后执行 |
memory_order_release | 本线程中,所有之前的写操作完成后才能执行本条原子操作 |
memory_order_acq_rel | 同时包含memory_order_acquire和memory_order_release标记 |
memory_order_consume | 本线程中,所有后续的有关本原子类型的操作,必须在本条原子操作完成之后执行 |
memory_order_seq_cst | 全部存取都按顺序执行 |
转载地址:http://dmuaa.baihongyu.com/