std::declval

来自cppreference.com
< cpp‎ | utility
 
 
实用工具库
类型的支持 (basic types, RTTI, type traits)
动态内存管理
错误处理
程序实用工具
可变参数函数
日期和时间
函数对象
initializer_list(C++11)
bitset
hash(C++11)
关系运算符
原文:
Relational operators
这段文字是通过 Google Translate 自动翻译生成的。
您可以帮助我们检查、纠正翻译中的错误。详情请点击这里
rel_ops::operator!=
rel_ops::operator>
rel_ops::operator<=
rel_ops::operator>=
对和元组
原文:
Pairs and tuples
这段文字是通过 Google Translate 自动翻译生成的。
您可以帮助我们检查、纠正翻译中的错误。详情请点击这里
pair
tuple(C++11)
apply(C++17)
make_from_tuple(C++17)
piecewise_construct_t(C++11)
piecewise_construct(C++11)
integer_sequence(C++14)
交换,前进和移动
原文:
Swap, forward and move
这段文字是通过 Google Translate 自动翻译生成的。
您可以帮助我们检查、纠正翻译中的错误。详情请点击这里
swap
exchange(C++14)
forward(C++11)
move(C++11)
move_if_noexcept(C++11)
类型操作
原文:
Type operations
这段文字是通过 Google Translate 自动翻译生成的。
您可以帮助我们检查、纠正翻译中的错误。详情请点击这里
declval(C++11)
as_const(C++17)
 
定义于头文件 <utility>
template<class T>
typename std::add_rvalue_reference<T>::type declval();
(C++11起)

将任意类型T转换成引用类型,令在decltype表达式中无需经过构造函数使用成员函数变得可行。

declval通常用于模板中,其可接受的模板参数通常可能无构造函数,但有同一成员函数,均返回所需类型。

注意因为不存在对于declval的定义,它只能用于不求值语境中;对包含此函数的表达式求值是错误。通常,若此函数为odr使用则程序是病态的。

目录

[编辑] 参数

(无)

[编辑] 返回值

不能调用,从而决不返回一个值。返回类型是T&&,除非T是(可以有cv资格的)void,此情况下返回类型是T

[编辑] 异常

noexcept指定:  
noexcept
  (C++11起)

[编辑] 示例

#include <utility>
#include <iostream>
 
struct Default { int foo() const { return 1; } };
 
struct NonDefault
{
    NonDefault(const NonDefault&) { }
    int foo() const { return 1; }
};
 
int main()
{
    decltype(Default().foo()) n1 = 1;                   // n1的类型是int
//  decltype(NonDefault().foo()) n2 = n1;               // 错误:无默认构造函数
    decltype(std::declval<NonDefault>().foo()) n2 = n1; // n2的类型是int
    std::cout << "n1 = " << n1 << '\n'
              << "n2 = " << n2 << '\n';
}

输出:

n1 = 1
n2 = 1

[编辑] 参阅

decltype指定符 定义等价于表达式类型的类型(C++11) [edit]
(C++11)
推导函数调用表达式的返回类型
(类模板) [edit]