◐ Shell
clean mode source ↗

std::make_signed — cppreference.com

Материал из cppreference.com

<tbody> </tbody>

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>
    );
}

Смотрите также