std::declval

来自cppreference.com
< cpp‎ | utility
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)
(C++20)
swap 与类型运算
(C++14)
declval
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)
 
在标头 <utility> 定义
template<class T>
typename std::add_rvalue_reference<T>::type declval() noexcept;
(C++11 起)

将任意类型 T 转换成引用类型,使得在 decltype 说明符的操作数中不必经过构造函数就能使用成员函数。

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

注意,std::declval 只能用于不求值语境,且不要求有定义;求值包含此函数的表达式是错误。正式的说法是 ODR 使用此函数的程序非良构。

参数

(无)

返回值

不能被调用,因此不会返回值。返回类型是 T&&,除非 T 是(可有 cv 限定的)void,此时返回类型是 T

示例

#include <utility>
#include <iostream>
 
struct Default
{
    int foo() const { return 1; }
};
 
struct NonDefault
{
    NonDefault() = delete;
    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) 获得表达式或实体的类型
(C++11)(C++20 中移除)(C++17)
推导以一组实参调用一个可调用对象的结果类型
(类模板)