Defined in header <utility> | ||
---|---|---|
template<class T> typename std::add_rvalue_reference<T>::type declval() noexcept; | (since C++11) |
Converts any type T
to a reference type, making it possible to use member functions in decltype
expressions without the need to go through constructors.
declval
is commonly used in templates where acceptable template parameters may have no constructor in common, but have the same member function whose return type is needed.
Note that because no definition exists for declval
, it can only be used in unevaluated contexts; it is an error to evaluate an expression that contains this function. Formally, the program is ill-formed if this function is odr-used.
(none).
Cannot be called and thus never returns a value. The return type is T&&
unless T
is (possibly cv-qualified) void
, in which case the return type is T
.
#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; // type of n1 is int // decltype(NonDefault().foo()) n2 = n1; // error: no default constructor decltype(std::declval<NonDefault>().foo()) n2 = n1; // type of n2 is int std::cout << "n1 = " << n1 << '\n' << "n2 = " << n2 << '\n'; }
Output:
n1 = 1 n2 = 1
decltype specifier | defines a type equivalent to the type of an expression (C++11) |
(C++11)(deprecated in C++17)(C++17) | deduces the result type of invoking a callable object with a set of arguments (class template) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
http://en.cppreference.com/w/cpp/utility/declval