decltype
( 实体 )(1)(c++11 起)
decltype
( 表达式 )(2)(c++11 起)
解释:
1) 如果实参是没有括号的标识表达式或没有括号的类成员访问表达式,那么 decltype
产生以该表达式命名的实体的类型。如果没有这种实体或该实参指名了一组重载函数,那么程序非良构。
decltype
产生其冬天的雪景被引用类型(在关于结构化绑定声明的说明中有所描述)。 如果实参是指名某个非类型模板形参的没有括号的标识表达式,那么 decltype
生成该模板形参的类型(当该模板形参以占位符类型声明时,类型会先进行任何所需的类型推导)。2) 如果实参是其他类型为 t 的任何表达式,且
如果 表达式 的值类别是亡值,将会decltype
产生 t&&;如果 表达式 的值类别是左值,将会 decltype
产生 t&;如果 表达式 的值类别是纯右值,将会 decltype
产生 t。 如果 表达式 是返回类类型纯右值的函数调用,或是右操作数为这种函数调用的逗号表达式,那么不会对该纯右值引入临时量。
如果 表达式 是除了(可带括号的)立即调用以外的 (c++20 起)纯右值,那么不会从该纯右值实质化临时对象:即这种纯右值没有结果对象。
该类型不需要是完整类型或拥有可用的析构函数,而且类型可以是抽象的。此规则不适用于其子表达式:decltype(f(g())) 中,g() 必须有完整类型,但 f() 不必。
注意:
如果对象的名字带有括号,那么它会被当做通常的左值表达式,从而 decltype(x) 和 decltype((x)) 通常是不同的类型。在难以或不可能以标准写法进行声明的类型时,decltype 很有用,例如 lambda 相关类型或依赖于模板形参的类型。
示例:个人资料怎么写
#include <iostream>#include <type_traits> struct a { double x; };const a* a; decltype(a->x) y; // y 的类型是 double(其声明类型)decltype((a->x)) z = y; // z 的类型是 const double&(左值表达式) template<typename t, typename u>auto add(t t, u u) -> decltype(t + u) // 返回类型依赖于模板形参{ // c++14 开始可以推导返回类型 return t+u;} int main() { int i = 33; decltype(i) j = i * 2; std::cout <<近视了怎样恢复视力 "i = " << i << ", " << "j = " << j << '\n'; std:中药丰胸:cout << "i 和 j 的类型相同吗?" << (std::is_same_v<decltype(i), decltype(j)> ? "相同" : "不同") << '\n'; auto f = [](int a, int b) -> int { return a * b; }; decltype(f) g = f; // lambda 的类型是独有且无名的张继的诗 i = f(2, 2); j = g(3, 3); std::cout << "i = " << i << ", " << "j = " << j << '\n';}
输出:
i 和 j 的类型相同吗?相同
i = 33, j = 66
i = 4, j = 9
到此这篇关于c++ decltype
说明符的文章就介绍到这了,更多相关decltype 说明符内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-04 01:34:20,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/8a947bfd8f220744456855531d1b9e80.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:C++ decltype 说明符.doc
本文 PDF 下载地址:C++ decltype 说明符.pdf
留言与评论(共有 0 条评论) |