decltype类型指示符:如果你希望从表达式的类型推断出要定义的变量的类型,但是却不想用表达式的值来初始化这个变量,那么你就可以使用decltype关键字,来说明这个变量了,它的作用是:选择并返回操作数的数据类型,但是不计算这个操作数。与auto类似,但是有区别。
decltype(f()/var) a=b; // a的类型就是f函数的返回值或者是var的类型。
注意:
1.decltype处理顶层const和引用的时候与auto是不同的,它会直接返回该变量的类型,而不会做忽略顶层const的操作
2.引用从来都作为其所值对象的同义词出现,而在decltype处是个例外,因为decltype仅仅只返回类型,而不做其他的操作,比如初始化等。
const int ci=0;,&cj=ci; decltype(ci) x=0; // x是一个const int 类型 decltype(cj) y=x; // y是一个 const int &类型 decltype(cj) z; // err ,此时z的类型时const int &类型,引用需要初始化
3.如果你想返回的是引用所指的类型,那么你只需要这样做:
int i=20,&r=i; decltype(r+0) k; // k是int型
这样获取的就是r+0这个表达式的值,即int型。
4.解指针操作和解引用操作返回的都是引用类型,因为解指针操作可以得到指针所指的对象并且还能给这个对象赋值,所以是引用,这里返回的是左值。
int i=10,&r=i,*p=&i; decltype(r) k; // err,k是int型引用,这里没有初始化 decltype(*p) k; // err,k是int型引用,这里没有初始化
5.decltype的结果类型与表达式类型密切相关,这就与"()"有关系了,有"()"意味着会被当做表达式,没有则才会被当作变量,表达式的返回一般是引用类型。decltype((变量))的结果永远都是引用,decltype(变量)的结果不一定是引用,如:
int i=0; decltype((i)) d; // err,d是int&,必须初始化 decltype(i) d; // d是int类型
6.decltype(变量)说明符里返回的是左值,那么也是变量的引用类型。
int a=3,b=4; decltype(a=b) d=a; // a=b是左值,返回的是int&类型总结
与auto的区别:处理顶层const和引用方式不同,decltype类型的选择与表达式密切相关而auto没有这种关系。
推导类型规则:
- 如果 exp 是一个不被括号( )包围的表达式,或者是一个类成员访问表达式,或者是一个单独的变量,那么 decltype(exp) 的类型就和 exp 一致,这是最普遍最常见的情况。
- 如果 exp 是函数调用,那么 decltype(exp) 的类型就和函数返回值的类型一致。
- 如果 exp 是一个左值,或者被括号( )包围,那么 decltype(exp) 的类型就是 exp 的引用;假设 exp 的类型为 T,那么 decltype(exp) 的类型就是 T&。


![[C++]decltype类型指示符 [C++]decltype类型指示符](http://www.mshxw.com/aiimages/31/1018348.png)
