std::add_pointer
Материал из cppreference.com
| Определён в заголовочном файле <type_traits>
|
||
| template< class T > struct add_pointer; |
(начиная с C++11) | |
Если T является типом ссылки, то предоставляет определение типа в члене type, которое будет равно указателю на тип, на который указывает ссылка, иначе если T является именем типа объекта, функции, у которой нет cv-квалификатора или квалификатора ссылки (начиная с C++17), void, то оно будет равен T*.
Иначе (если T является типом функции, который содержит в себе cv-квалификатор или квалификатор ссылки), то оно будет содержать T. |
(начиная с C++17) |
Содержание |
[править] Типы-члены
| Имя | Определение |
type
|
Указатель на T, или тип, на который указывает T
|
[править] Вспомогательные типы
| template< class T > using add_pointer_t = typename add_pointer<T>::type; |
(начиная с C++14) | |
[править] Возможная реализация
namespace detail { template< class T, bool is_function_type = false > struct add_pointer { using type = typename std::remove_reference<T>::type*; }; template< class T > struct add_pointer<T, true> { using type = T; }; template< class T, class... Args > struct add_pointer<T(Args...), true> { using type = T(*)(Args...); }; template< class T, class... Args > struct add_pointer<T(Args..., ...), true> { using type = T(*)(Args..., ...); }; } // namespace detail template< class T > struct add_pointer : detail::add_pointer<T, std::is_function<T>::value> {}; |
[править] Пример
Запустить этот код
#include <iostream> #include <type_traits> int main() { int i = 123; int& ri = i; typedef std::add_pointer<decltype(i)>::type IntPtr; typedef std::add_pointer<decltype(ri)>::type IntPtr2; IntPtr pi = &i; std::cout << "i = " << i << "\n"; std::cout << "*pi = " << *pi << "\n"; static_assert(std::is_pointer<IntPtr>::value, "IntPtr должен быть указателем"); static_assert(std::is_same<IntPtr, int*>::value, "IntPtr должен быть указателем на int"); static_assert(std::is_same<IntPtr2, IntPtr>::value, "IntPtr2 должен быть равным IntPtr"); typedef std::remove_pointer<IntPtr>::type IntAgain; IntAgain j = i; std::cout << "j = " << j << "\n"; static_assert(!std::is_pointer<IntAgain>::value, "IntAgain не должен быть указателем"); static_assert(std::is_same<IntAgain, int>::value, "IntAgain должен быть int"); }
Вывод:
i = 123 *pi = 123 j = 123
[править] См. также
| (C++11) |
Проверяет является ли тип типом указателя или нет (шаблон класса) |
| (C++11) |
Удаляет указатель от данного типа (шаблон класса) |

