1.原子弹级更新——Variadic Templates
含义:数量不定的模板参数,模板使得类型可以任意指定,而Variadic Templates进一步让模板参数的数量也可以任意指定
注意:pack的模板参数数量可以为0;需要定义终止条件
用途:
- 比如实现print函数,可以打印任意数量的,任意类型的数据
- 还可以方便地实现递归函数,比如hash_val的计算
- 可以实现递归继承,比如实现tuple(可以将不同类型,任意数量的数据存在一起)
2. 模板表达式的> >中间的空格可以省略
3. nullptr
在2011之前空指针往往使用0或者NULL来赋值,(NULL是一个宏,值为0),但是这种方式有时会引发歧义,所以C++ 11引入nullptr来初始化空指针。
4. auto
含义:自动类型推导
用途:自动类型推导,举例如下:
auto i = 42;
double f();
auto d = f();
主要用途1:类型太长
vector<string> v;
auto pos = v.begin();
标准库也用了(2011后的使用auto代替一长串的返回类型)
2:类型太复杂
auto l = [] (int x) -> bool {
}
这时候l就可以指代lambda表达式
5. 统一初始化
之前的初始方式可以通过(), {},或者=,比较混乱,如下:
Rect r1 = {3, 7, 20, 25, &area, &print};
Rect r1{3, 7, 20, 25};
int ia[6] = {27, 210, 12, 47, 109, 83};
现在可以统一成一种形式,就是使用{},如下:
vector<int> v{2,3,4,5};
背后原理用了initializer_list,如果有一个特定数量的构造函数,{}内的元素会被分解成最小单位去调用,如果有构造函数参数是initializer_list<T>,则直接整包传过去调用。
6. initializer_list
初始化为0,不是任意值
更安全:(初始化时不允许窄化)
initializer_list接收不定长参数包,可以用来实现print()
initializer_list底层实现:
用到了array
注意:initialzier_list拷贝是浅拷贝
stl大量使用:
max更加强大了,可以是任意数量参数:
7. array
对数组的一种封装,可以兼容迭代器,这样使得array可以调用很多算法,tr1实现如下: