C++11新特性
类型推导
1.auto
作用:让编译器在编译期自动推导出变量的类型
- 必须初始化
- auto不能定义数组
- 不能推导出模板参数
- 在不声明为引用或指针时,会忽略等号右边的引用类型,和const, volatile类型。
- 声明为引用或指针时,会保留。
2. decltype
decltype用于推导表达式类型。
decltype会保留引用和cv属性(const,volatile)
对于decltype(exp)有:
- exp是表达式,decltype(exp)和exp类型相同
- exp是函数调用,decltype(exp)和函数返回值类型相同
- 其他情况,若exp是左值,decltype(exp)是exp类型的左值引用
例子
template <typename T, typename U> auto add(T t, U u) -> decltype(t + u) { return t + u; }
右值引用
定义:右值引用就是必须绑定到右值的引用,通过&&来获得右值引用。
性质:只能绑定到一个将要销毁的对象,于是,我们可以自由地将一个右值引用的资源绑定到另一个对象中。
常规的引用,我们可以称之为左值引用。
1.左值右值
左值:有地址,可以放在等号左边
右值:没有地址,不可以放在等号左边(字面量,临时量)
++i, --i 是左值,i++, i-- 是右值。
++i, --i 是左值,i++, i-- 是右值。
2.右值引用
右值有两个特性:所引用的对象将要被销毁;该对象没有其他用户
这意味着:使用右值引用的代码可以自由地接管所引用的对象的资源
右值引用本身是一个左值:接管资源后,资源就有了地址和用户,因此,右值变成了左值。
3.std::move
虽然不能把右值引用绑定到左值上,但可以使用std::move把一个左值转化为对应的右值引用类型。
浅拷贝:拷贝指针
深拷贝:重新开辟内存,并复制内容
nullptr
nullptr:特殊类型的字面量。
用来替代NULL和0。NULL在有的编译器中定义为((void*)0),有的定义为0。因此,NULL具有二义性,在下面情况会发生问题。
void test(char*); void test(int);使用test(NULL)时,编译器会不知道使用哪一个重载。
范围for循环
for (auto c : string) { cout << c; }可以简化遍历。
列表初始化
double d = 3.124564564654 int a = {d}; int a = d;使用花括号来进行初始化称为列表初始化。
对于内置类型,使用列表初始化时,如果存在丢失信息的风险,编译器会报错。
lambda表达式
表示一个可调用的代码单元,可以理解为没有命名的内联函数,用于一次性的场景。
1.语法
[capture list] (parameter list) ->return type {functon body}我们可以忽略参数列表和返回类型,但必须永远包含捕获列表和函数体。
变量捕获
- []不捕获
- [&]引用捕获
- [=]拷贝捕获
- [=, &foo]引用捕获foo,拷贝捕获其他
- [bar]拷贝捕获bar
- [this]捕获所在类的this指针
lanbda使用algorithm库
std::sort(arr, arr+6, [](int &a, int &b){return a > b});