使用这个关键字的作用是找到某一个表达式的类型。其实是类似于typeof但是没有typeof,其实每一个类型是有一个typeid的其实是你是可以获得这个id并且打印出来的,但是ID打印出来也没有什么意义。
c++11导入了一个新的关键字,就是decltype
具体的使用可以看下方
当我们想要知道一个容器里面包含了什么类型的元素的时候我们可以使用decltype来获取里面的数据类型,通过对象来取得type其实就是decltype的用法和出现的意义。
map<string,float> coll;
decltype(coll)::value_type elem;
当然除了这种用法以外,还可以用来定义函数的返回类型
下面这种使我们所希望的应用方式,这个函数的返回值的类型就是decltype x+y之后结果的类型。
但是编译是过不了的,因为说实话编译时从左到右的,先遇到了x与y并不知道是什么类型的元素,所以编译之后会报错。那正确的使用方式是什么呢?
template <typename T1,typename T2>
decltype(x+y)add(T1 x, T2 y);
正确的写法
c++为了解决上面那一种尴尬的情况出现了新的语法
template<typename T1 , typename T2>
auto add(T1 x , T2 y)->decltype(x + y);
先用一个auto类型代表我们目前不知道是什么类型,之后在后面还需要制定decltype返回类型是什么样子的,新的函数类型的指定方式。
或者是这样使用
template <typename T>
void test(T obj)
{
map<strting ,float>::value_type elem1;
map<string , float> coll;
decltype(coll):: value_type elem2;
typedef typename decltype(obj)::iterator iType;
decltype(obj) anotherObj(obj);
}
还可以作为lambda的传递值
auto cmp = [](const Person& p1 , const Person& p2){
return p1.lastname() < p2.lastname()
|| (p1.lastname() == p2.lastname())
&& (p1.firstname() < p2.firstname());
}
std::set<Person,decltype(cmp)> coll(cmp);