C++11新特性
auto
auto 并不能代表一个实际的类型声明,只是一个类型
声明的占位符
使用auto声明的变量必须马上初始化,以让编译器推断出
它的实际类型,并在编译时将auto占位符替换为真正的类型;
旧标准auto是具有自动存储期的局部变量,在新标准中作为类型指示符;
auto int i = 0;
int x = 0;
const auto e = x;//e->const int
auto f = e;//f->int,原因:当表达式带有const属性时,
auto会把const属性抛弃掉,推导成non-const类型int;
const auto& g= x;
auto& h = g;//推导出h->const int&,当auto和引用结合时
auto的推导将保留表达式的const属性;
结论
1.当不声明为指针或引用时,auto的推导结果和初始化表达式
抛弃引用和cv(const、volatile)限定符后类型一致;
2.当声明为指针或引用时,auto的推导结果将保持初始化表达式的csv属性;
3.auto的限制
不能用于函数的参数
void func(auto a);
不能用于非静态成员变量,auto编译阶段进行类型推导,非静态成员变量编译时变量
还没有进行初始化
struct foo{
auto var1=0;//error
static const auto var2=0;//ok,var2->static const int;
};
无法定义数组
int arr[10]={0};
auto aa=arr;//ok,aa->int*
auto rr[10]=arr;//error,auto无法定义数组
无法推导出模板参数
Bar bar;
Bar bb=bar;//error,auto无法推导出模板参数
1.一般用于iterator迭代器类型声明
2.定义一个泛型函数func,多个类中都有
get()静态返回值函数,但返回类型不同,若想在
func中调用get函数并获取其返回值,需要使用auto进行
变量类型声明;
decltype
decltype(exp)
可以通过表达式推出它的类型本身,和auto不同之处是auto只能
根据变量的初始化表达式推导出变量具有的类型,若想通过某个表达式
得到类型,但不希望新新变量和这个表达式具有相同的值,decltype就派上用场了;
和auto相同处是都可以加上指针、引用、cv限定符;