标签:11 decltype 推导 int 代码优化 && const pi
1. decltype介绍
在上一篇中我们简单介绍了auto, auto就是一个"站位符",在编译时编译器根据初始化的值的类型来推导当前定义的变量的类型. 所以使用auto定义变量时一定要对该变量进行初始化. 如果我们希望得到类型, 而不给新定义的变量进行初始化时要怎么做呢? decltype关键字, 用来在编译时推导出一个表达式的类型.
decltype(exp)
其中, exp是一个表达式(expression). 但是这个表达式的值肯定是可推导的.
decltype简单使用:
int x = 0; // int
decltype (x) y = 1; // y被推导为int decltype推导结果为int
decltype (x+y) z = 0; // z被推导为int decltype推导结果为int
const int & i = x; // int const &
decltype (i) j = y; // j被推导为 int const & decltype推导结果为int const &
const decltype (z) * p = &z; // p被推导为int const * decltype推导为int
decltype (z) * pi = &z; // pi被推导为int * decltype推导为int
decltype (pi) * pp = π // pp被推导为int ** decltype推导为int*
int *** ppp = nullptr; // int***
decltype(ppp) pppp; // pppp被推导为int *** decltype推导为int ***
decltype(ppp)* ppppp; // ppppp被推导为int **** decltype推导为int ***
int r = 10;
int &rr = r;
decltype (rr) dr = r; // dr被推导为int & decltype推导为int &
decltype (rr) & drr = r; // drr被推导为int & decltype推导为int &
decltype (rr) && drrr = r; // drrr被推导为int & decltype推导为int &
int && rv = 10; // int &&
decltype(rv) rrv = 10; // rrv被推导为int && decltype推导为int &&
decltype(rv) & rrrv = r; // rrrv被推导为int & decltype推导为int &&,但由于引用折叠(由于左值引用&具有传染性),所以& rrrv是左值,rrrv也就被传染为int &.
decltype(rv) && rrrrv = 10; // rrrrv被推导为int && decltype推导为int &&,但由于引用折叠,int && &&就是int &&.
标签:11,decltype,推导,int,代码优化,&&,const,pi 来源: https://www.cnblogs.com/dog-pi/p/16522280.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。