std::type_identity
From cppreference.com
| Defined in header <type_traits>
|
||
template< class T > struct type_identity; |
(since C++20) | |
Provides the member typedef type that names T (i.e., the identity transformation).
If the program adds specializations for std::type_identity, the behavior is undefined.
Member types
| Name | Definition |
type
|
T
|
Helper types
template< class T > using type_identity_t = type_identity<T>::type; |
(since C++20) | |
Possible implementation
template<class T>
struct type_identity { using type = T; };
|
Notes
std::type_identity can be used to establish non-deduced contexts in template argument deduction.
| Feature-test macro | Value | Std | Feature |
|---|---|---|---|
__cpp_lib_type_identity |
201806L |
(C++20) | std::type_identity
|
Example
Run this code
#include <iostream>
#include <type_traits>
template<class T>
T foo(T a, T b) { return a + b; }
template<class T>
T bar(T a, std::type_identity_t<T> b) { return a + b; }
int main()
{
// foo(4.2, 1); // error, deduced conflicting types for 'T'
std::cout << bar(4.2, 1) << '\n'; // OK, calls bar<double>
}
Output:
5.2
See also
(C++20) |
function object that returns its argument unchanged (class) |