std::make_signed — cppreference.com
Материал из cppreference.com
<tbody> </tbody>
|
|
(начиная с C++11) | |
Если T является целым числом (кроме bool) или типом перечисления, предоставляет typedef элемент type, который является целочисленным типом со знаком, соответствующим T с теми же cv-квалификаторами.
Если T со знаком или без знака char, short, int, long, long long, предоставляет знаковый тип из этого списка, соответствующий T.
Если T является типом перечисления или char, wchar_t, char8_t (начиная с C++20), char16_t, char32_t, предоставляет целочисленный тип со знаком с наименьшим рангом, имеющим тот же sizeof, что и T.
|
Иначе поведение не определено. |
(до C++20) |
|
Иначе программа некорректна. |
(начиная с C++20) |
Поведение программы, добавляющей специализации для std::make_signed не определено.
Типы-элементы
| Имя | Определение |
type
|
знаковый целочисленный тип, соответствующий T
|
Вспомогательные типы
<tbody> </tbody>
|
|
(начиная с C++14) | |
Пример
#include <type_traits> enum struct E : unsigned short {}; int main() { using char_type = std::make_signed_t<unsigned char>; using int_type = std::make_signed_t<unsigned int>; using long_type = std::make_signed_t<volatile unsigned long>; using enum_type = std::make_signed_t<E>; static_assert( std::is_same_v<char_type, signed char> and std::is_same_v<int_type, signed int> and std::is_same_v<long_type, volatile signed long> and std::is_same_v<enum_type, signed short> ); }