多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
c++11新特性——decltype decltype是C++11添加的一个新的关键字,目的是选择并返回操作数的数据类型,重要的是,在此过程中编译器分析表达式并得到它的类型,却不实际计算表达式的值。 对于内置类型的对象,使用decltype很直观,但当参数为复合类型的时候就应该注意一些使用细节问题。 1.当decltype作用于数组的时候就应该小心了,本文作者(CSDN   iaccepted)。 ~~~ intiarr[10] = {0}; decltype(iarr)ib; ~~~ 这个时候ib的定义等价于 int ib[10];两者是一样的,不要认为ib是一个指针了,它是一个正宗的数组。我们可以验证一下: ~~~ cout<< sizeof(ib) << endl; ~~~ 如果ib是10个元素数组的指针很明显将输出4,但是如果ib表示数组类型则会输出4*10 = 40.这地方完全类似于原有的typedef关键字。         ~~~ typedefint iarr[10]; iarrib; //跟这里的decltype(iarr) ib是一样的功能。 ~~~ 2.就是因为上述的这个细节,在写函数返回值的时候就要注意类型问题。 ~~~ decltype(iarr)function(){ //本文作者(CSDN iaccepted) return***; } ~~~ 上述的语句就是错误的,因为很明显decltype(iarr) 表示以数组作为返回值,这在c++中是不允许的。 ~~~ intia[3]; intiaa[][3] = { { 0 }, { 1 }, { 2 }, { 3 }, { 4 } }; intiab[][3] = { { 1 }, { 2 }, { 3 }, { 4 }, { 5 } }; ~~~ 这时候我们写个函数通过参数决定是使用iaa数组还是iab数组,也就是返回值要返回哪个数组首地址,要返回二维数组的首地址当然有多种写法,这里主要说一下使用decltype的注意点。         ~~~ decltype(ia)*function(int index){ if (index == 1)returniaa; elsereturn iab; }//本文作者(CSDN iaccepted 凌风) ~~~ 这样就能实现,decltype(ia)返回一个数组类型,该类型为指向一个有三个整形元素的数组,所以decltype(ia) * 就能表示一个指向数组元素的指针,即该指针指向一个数组,数组内的每个元素又是包含三个整数的数组元素。以上面的例子来说,函数的返回值若记为p,则p指向iaa[0]而p+1则指向iaa[1],*p 为iaa[0][0]的地址 *p + 1 为iaa[0][1]的地址,这里就说多了,因为这就是普通指针的特性,ok。 3.当decltype参数为指针的解引用的话就要注意了,此时返回引用类型而不是解引用后的类型。         ~~~ intia[3] = { 1, 2, 3 };//本文作者(CSDN iaccepted 凌风) ~~~         decltype(*ia)b; //这就会出错,因为此时b是一个指向整形变量的引用,而引用必须在定义的时候初始化。 这里为什么返回引用其实很好理解,因为*ia就是当前指针所指对象的一个引用,因为我们可以直接给*ia赋值来改变ia所指对象的值,比如         ~~~ *ia= 5; ~~~ 此时ia[0] 就变成5. 同理        ~~~ decltype(ia[1])b; //也是错误的,因为b为一个引用必须初始化。 //本文作者(CSDN iaccepted 凌风) ~~~ 好了,暂时就想到这么多,先写到这吧 本文作者:CSDN   iaccepted  凌风,博客地址:[http://blog.csdn.net/iaccepted](http://blog.csdn.net/iaccepted)