std::decay
Материал из cppreference.com
Определено в заголовочном файле <type_traits> | ||
template<class T > struct decay; | (начиная с C++11) | |
Выполняет преобразования типов, эквивалентные тем, которые выполняются при передаче аргументов функции по значению. Формально:
- Если
T
именует тип "массив элементов типаU
" или "ссылка на массив элементов типаU
", определение typedef элементаtype
равно U*.
- Иначе, если
T
является функциональным типомF
или ссылкой на него, определение typedef элементаtype
равно std::add_pointer<F>::type.
- Иначе typedef элемент
type
равен std::remove_cv<std::remove_reference<T>::type>::type.
Поведение программы, добавляющей специализации для std::decay
не определено.
Содержание |
[править]Тип-элемент
Имя | Определение |
type | результат применения преобразования распада типа к T |
[править]Вспомогательный тип
template<class T > using decay_t =typename decay<T>::type; | (начиная с C++14) | |
[править]Возможная реализация
template<class T >struct decay {private:typedeftypenamestd::remove_reference<T>::type U;public:typedeftypenamestd::conditional<std::is_array<U>::value, typenamestd::add_pointer<typenamestd::remove_extent<U>::type>::type, typenamestd::conditional<std::is_function<U>::value, typenamestd::add_pointer<U>::type, typenamestd::remove_cv<U>::type>::type>::type type;}; |
[править]Пример
Запустить этот код
#include <type_traits> template<typename T, typename U>constexprbool is_decay_equ =std::is_same_v<std::decay_t<T>, U>; int main(){ static_assert( is_decay_equ<int, int>&&! is_decay_equ<int, float>&& is_decay_equ<int&, int>&& is_decay_equ<int&&, int>&& is_decay_equ<constint&, int>&& is_decay_equ<int[2], int*>&&! is_decay_equ<int[4][2], int*>&&! is_decay_equ<int[4][2], int**>&& is_decay_equ<int[4][2], int(*)[2]>&& is_decay_equ<int(int), int(*)(int)>);}
[править]Смотрите также
(C++20) | объединяет std::remove_cv и std::remove_reference (шаблон класса) |
implicit conversion | преобразования массива в указатель, функции в указатель, левостороннего значения в правостороннее |