std::make_unsigned

来自cppreference.com
< cpp‎ | types
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)
 
 
在标头 <type_traits> 定义
template< class T >
struct make_unsigned;
(C++11 起)

T 是整数(除 bool )或枚举类型,则提供成员 typedef type ,它是对应 T 的拥有相同 cv 限定符的无符号整数类型。

T 为有符号或无符号的 charshortintlonglong long ;则提供来自此列表的对应 T 的无符号类型。

T 为枚举类型或 charwchar_­t char8_­t (C++20 起)char16_­tchar32_­t ;则提供与 T 有相同 sizeof 的有最小等级的无符号整数类型。

否则,行为未定义。

(C++20 前)

否则,程序为非良构。

(C++20 起)

添加 std::make_unsigned 的特化的程序行为未定义。

成员类型

成员 定义
type 对应 T 的无符号整数类型

辅助类型

template< class T >
using make_unsigned_t = typename make_unsigned<T>::type;
(C++14 起)

示例

#include <iostream>
#include <type_traits>
 
int main() {
    typedef std::make_unsigned<char>::type char_type;
    typedef std::make_unsigned<int>::type int_type;
    typedef std::make_unsigned<volatile long>::type long_type;
 
    bool ok1 = std::is_same<char_type, unsigned char>::value; 
    bool ok2 = std::is_same<int_type, unsigned int>::value;
    bool ok3 = std::is_same<long_type, volatile unsigned long>::value;
 
    std::cout << std::boolalpha
    << "char_type is 'unsigned char'?          : " << ok1 << '\n'
    << "int_type  is 'unsigned int'?           : " << ok2 << '\n'
    << "long_type is 'volatile unsigned long'? : " << ok3 << '\n';
}

输出:

char_type is 'unsigned char'?          : true
int_type  is 'unsigned int'?           : true
long_type is 'volatile unsigned long'? : true

参阅

(C++11)
检查类型是否为有符号算术类型
(类模板)
检查类型是否为无符号算术类型
(类模板)
使给定的整数类型有符号
(类模板)