std::make_signed
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <type_traits>
|
||
template< class T > struct make_signed; |
(начиная с 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> template< class T > using make_signed_t = typename make_signed<T>::type; |
(начиная с 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>
);
}
Смотрите также
(C++11) |
проверяет, является ли тип арифметическим типом со знаком (шаблон класса) |
(C++11) |
проверяет, является ли тип беззнаковым арифметическим типом (шаблон класса) |
(C++11) |
делает данный целочисленный тип беззнаковым (шаблон класса) |