C++标准模板(STL)- 类型支持 (定宽整数类型)(int8_t,int_fast8_t,int_least8_t,intmax_t,intptr_t)

定宽整数类型

类型

|---------------------------------------------------------|----------------------------------------------------------------------|
| 定义于头文件 <cstdint> ||
| int8_tint16_tint32_tint64_t (可选) | 分别为宽度恰为 8、16、32 和 64 位的有符号整数类型 无填充位并对负值使用补码 (仅若实现支持该类型才提供) (typedef) |
| int_fast8_tint_fast16_tint_fast32_tint_fast64_t | 分别为宽度至少有 8、16、32 和 64 位的最快的有符号整数类型 (typedef) |
| int_least8_tint_least16_tint_least32_tint_least64_t | 分别为宽度至少有 8、16、32 和 64 位的最小的有符号整数类型 (typedef) |
| intmax_t | 最大宽度的有符号整数类型 (typedef) |
| intptr_t (可选) | 足以保有指针的有符号整数类型 (typedef) |
| uint8_tuint16_tuint32_tuint64_t (可选) | 宽度恰为 8、16、32 和 64 位的无符号整数类型 (仅若实现支持该类型才提供) (typedef) |
| uint_fast8_tuint_fast16_tuint_fast32_tuint_fast64_t | 分别为宽度至少有 8、16、32 和 64 位的最快无符号整数类型 (typedef) |
| uint_least8_tuint_least16_tuint_least32_tuint_least64_t | 分别为宽度至少有 8、16、32 和 64 位的最小无符号整数类型 (typedef) |
| uintmax_t | 最大宽度的无符号整数类型 (typedef) |
| uintptr_t (可选) | 足以保有指针的无符号整数类型 (typedef) |

调用示例

复制代码
#include <iostream>
#include <cstdint>

int main()
{
    //分别为宽度恰为 8、16、32 和 64 位的有符号整数类型,无填充位并对负值使用补码
    std::cout << "sizeof(int8_t):           " << sizeof(int8_t) << std::endl;
    std::cout << "sizeof(int16_t):          " << sizeof(int16_t) << std::endl;
    std::cout << "sizeof(int32_t):          " << sizeof(int32_t) << std::endl;
    std::cout << "sizeof(int64_t):          " << sizeof(int64_t) << std::endl;
    std::cout << std::endl;

    //分别为宽度至少有 8、16、32 和 64 位的最快的有符号整数类型
    std::cout << "sizeof(int_fast8_t):      " << sizeof(int_fast8_t) << std::endl;
    std::cout << "sizeof(int_fast16_t):     " << sizeof(int_fast16_t) << std::endl;
    std::cout << "sizeof(int_fast32_t):     " << sizeof(int_fast32_t) << std::endl;
    std::cout << "sizeof(int_fast64_t):     " << sizeof(int_fast64_t) << std::endl;
    std::cout << std::endl;

    //分别为宽度至少有 8、16、32 和 64 位的最小的有符号整数类型
    std::cout << "sizeof(int_least8_t):     " << sizeof(int_least8_t) << std::endl;
    std::cout << "sizeof(int_least16_t):    " << sizeof(int_least16_t) << std::endl;
    std::cout << "sizeof(int_least32_t):    " << sizeof(int_least32_t) << std::endl;
    std::cout << "sizeof(int_least32_t):    " << sizeof(int_least64_t) << std::endl;
    std::cout << std::endl;

    //宽度恰为 8、16、32 和 64 位的无符号整数类型
    std::cout << "sizeof(uint8_t):          " << sizeof(uint8_t) << std::endl;
    std::cout << "sizeof(uint16_t):         " << sizeof(uint16_t) << std::endl;
    std::cout << "sizeof(uint32_t):         " << sizeof(uint32_t) << std::endl;
    std::cout << "sizeof(uint64_t):         " << sizeof(uint64_t) << std::endl;
    std::cout << std::endl;

    //分别为宽度至少有 8、16、32 和 64 位的最快无符号整数类型
    std::cout << "sizeof(uint_fast8_t):     " << sizeof(uint_fast8_t) << std::endl;
    std::cout << "sizeof(uint_fast16_t):    " << sizeof(uint_fast16_t) << std::endl;
    std::cout << "sizeof(uint_fast32_t):    " << sizeof(uint_fast32_t) << std::endl;
    std::cout << "sizeof(uint_fast64_t):    " << sizeof(uint_fast64_t) << std::endl;
    std::cout << std::endl;

    //分别为宽度至少有 8、16、32 和 64 位的最小无符号整数类型
    std::cout << "sizeof(uint_least8_t):    " << sizeof(uint_least8_t) << std::endl;
    std::cout << "sizeof(uint_least16_t):   " << sizeof(uint_least16_t) << std::endl;
    std::cout << "sizeof(uint_least32_t):   " << sizeof(uint_least32_t) << std::endl;
    std::cout << "sizeof(uint_least32_t):   " << sizeof(uint_least64_t) << std::endl;
    std::cout << std::endl;

    //最大宽度的有符号整数类型
    std::cout << "sizeof(intmax_t):         " << sizeof(intmax_t) << std::endl;
    //足以保有指针的有符号整数类型
    std::cout << "sizeof(intptr_t):         " << sizeof(intptr_t) << std::endl;
    std::cout << "sizeof(uintmax_t):        " << sizeof(uintmax_t) << std::endl;
    std::cout << "sizeof(uintptr_t):        " << sizeof(uintptr_t) << std::endl;
    std::cout << std::endl;
    return 0;
}

输出

相关推荐
今儿敲了吗6 分钟前
07| 高精度除法
c++
范纹杉想快点毕业1 小时前
嵌入式系统架构之道:告别“意大利面条”,拥抱状态机与事件驱动
java·开发语言·c++·嵌入式硬件·算法·架构·mfc
陳10301 小时前
C++:map和set的使用
开发语言·c++
苏宸啊1 小时前
list底层实现
c++·list
近津薪荼1 小时前
递归专题(4)——两两交换链表中的节点
数据结构·c++·学习·算法·链表
乐观勇敢坚强的老彭1 小时前
c++寒假营day01下午
c++·算法
散峰而望1 小时前
【算法竞赛】树
java·数据结构·c++·算法·leetcode·贪心算法·推荐算法
近津薪荼1 小时前
递归专题(3)——反转链表
数据结构·c++·学习·算法·链表
code monkey.2 小时前
【Linux之旅】Linux 动静态库与 ELF 加载全解析:从制作到底层原理
linux·服务器·c++·动静态库
水饺编程2 小时前
第4章,[标签 Win32] :文本的格式化,等待完善
c语言·c++·windows·visual studio