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

news2025/1/22 22:05:20

定宽整数类型

类型

定义于头文件 <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;
}

输出

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1061069.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

进程调度算法之先来先服务(FCFS),短作业优先(SJF)以及高响应比优先(HRRN)

1.先来先服务&#xff08;FCFS&#xff09; first come first service 1.算法思想 主要从“公平”的角度考虑(类似于我们生活中排队买东西的例子) 2.算法规则 按照作业/进程到达的先后顺序进行服务。 3.用于作业/进程调度 用于作业调度时&#xff0c;考虑的是哪个作业先…

Spring 原理

它是一个全面的、企业应用开发一站式的解决方案&#xff0c;贯穿表现层、业务层、持久层。但是 Spring仍然可以和其他的框架无缝整合。 1 Spring 特点 轻量级控制反转面向切面容器框架集合 2 Spring 核心组件 3 Spring 常用模块 4 Spring 主要包 5 Spring 常用注解 bean…

【HTTP】URL结构、HTTP请求和响应的报文格式、HTTP请求的方法、常见的状态码、GET和POST有什么区别、Cookie、Session等重点知识汇总

目录 URL格式 HTTP请求和响应报文的字段&#xff1f; HTTP请求方法 常见的状态码 GET 和 POST 的区别 Cookie 和 Session URL格式 &#xff1f;&#xff1a;是用来分割URL的主体部分&#xff08;通常是路径&#xff09;和查询字符串&#xff08;query string&#xff09;…

MyBatisPlus(九)模糊查询

说明 模糊查询&#xff0c;对应SQL语句中的 like 语句&#xff0c;模糊匹配“要查询的内容”。 like /*** 查询用户列表&#xff0c; 查询条件&#xff1a;姓名包含 "J"*/Testvoid like() {String name "J";LambdaQueryWrapper<User> wrapper ne…

十天学完基础数据结构-第六天(树(Tree))

树的基本概念 树是一种层次性的数据结构&#xff0c;它由节点组成&#xff0c;这些节点按照层次关系相互连接。树具有以下基本概念&#xff1a; 根节点&#xff1a;树的顶部节点&#xff0c;没有父节点。 子节点&#xff1a;树中每个节点可以有零个或多个子节点。 叶节点&am…

力扣第102题 广度优先搜索 二叉数 c++

题目 102. 二叉树的层序遍历 中等 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;[[3],[9,20…

八大排序算法汇总(C语言实现)

本专栏内容为&#xff1a;八大排序汇总 通过本专栏的深入学习&#xff0c;你可以了解并掌握八大排序以及相关的排序算法。 &#x1f493;博主csdn个人主页&#xff1a;小小unicorn ⏩专栏分类&#xff1a;八大排序汇总 &#x1f69a;代码仓库&#xff1a;小小unicorn的代码仓库…

【1++的刷题系列】之双指针

&#x1f44d;作者主页&#xff1a;进击的1 &#x1f929; 专栏链接&#xff1a;【1的刷题系列】 文章目录 一&#xff0c;什么是双指针二&#xff0c;相关例题例一例二例三例四例五 一&#xff0c;什么是双指针 常见的双指针有两种形式&#xff1a;一种是对撞指针&#xff08…

tinymce富文本编辑器【tip】

项目场景&#xff1a; tinymce富文本编辑器在iview的modal框中显示的问题 问题描述 最近在使用tinymceiviewvue写项目&#xff0c;在富文本编辑器配合弹框一起使用时&#xff0c;总是存在问题&#xff1a;弹框弹出的时候&#xff0c;富文本编辑器不能点击&#xff0c;鼠标的光…

【软考】PV 操作

#国庆发生的那些事儿# 临界资源: 诸进程间需要互斥方式对其进行共享的资源&#xff0c;如打印机、磁带机等临界区: 每个进程中访问临界资源的那段代码称为临界区信号量: 是一种特殊的变量。 信号量的值与相应资源的使用情况有关: ①: 当信号量的值大于0时&#xff0c;表示当…

Lucene学习总结之Lucene的索引文件格式

四、具体格式 上面曾经交代过&#xff0c;Lucene保存了从Index到Segment到Document到Field一直到Term的正向信息&#xff0c;也包括了从Term到Document映射的反向信息&#xff0c;还有其他一些Lucene特有的信息。下面对这三种信息一一介绍。 4.1. 正向信息 Index –> Seg…

Spring 体系架构模块和三大核心组件介绍

Spring架构图 模块介绍 1. Spring Core&#xff08;核心容器&#xff09;&#xff1a;提供了IOC,DI,Bean配置装载创建的核心实现。 spring-core &#xff1a;IOC和DI的基本实现 spring-beans&#xff1a;BeanFactory和Bean的装配管理(BeanFactory) spring-context&#xff1…

LLMs 用强化学习进行微调 RLHF: Fine-tuning with reinforcement learning

让我们把一切都整合在一起&#xff0c;看看您将如何在强化学习过程中使用奖励模型来更新LLM的权重&#xff0c;并生成与人对齐的模型。请记住&#xff0c;您希望从已经在您感兴趣的任务上表现良好的模型开始。您将努力使指导发现您的LLM对齐。首先&#xff0c;您将从提示数据集…

<C++> 模板-上

目录 前言 一、函数模板 1. 概念 2. 格式 3. 原理 4. 函数模板的实例化 4.1 隐式实例化 4.2 显示实例化 5. 模板参数的匹配原则 5.1 5.2 5.3 二、类模板 1. 类模板定义格式 2. 类模板的实例化 总结 前言 如何实现一个通用的函数&#xff0c;函数可以实现两个类型的交换&…

C++_pen_友元

友元&#xff08;破坏封装&#xff09; 我故意让别人能使用我的私有成员 友元类 friend class B;友元函数 friend void func();友元成员函数 friend void A::func();例 #include <stdio.h>class A;class C{ public:void CprintA(A &c); };class B{ public:void Bpri…

jira 浏览器插件在问题列表页快速编辑问题标题

jira-issueTable-quicker 这是一个可以帮助我们在问题表格页快速编辑问题的浏览器插件 github 地址 功能介绍 jira 不可否认是一个可以帮助有效提高工作效率的工具&#xff0c;但是我们在使用 jira 时使用问题表格可以让我们看到跟多的内容而不用关注细节&#xff0c;但是目…

c与c++中的字符串

在c中&#xff0c;string本质上是一个类&#xff1b; string与char *有些区别&#xff1a; char*是一个指针&#xff1b;string是一个类&#xff0c;类内封装了char*&#xff0c;管理这一个字符串&#xff0c;是一个char*的容器 在使用string类型时&#xff0c;要加上其头文…

用向量数据库Milvus Cloud 搭建AI聊天机器人

加入大语言模型(LLM) 接着,需要在聊天机器人中加入 LLM。这样,用户就可以和聊天机器人开展对话了。本示例中,我们将使用 OpenAI ChatGPT 背后的模型服务:GPT-3.5。 聊天记录 为了使 LLM 回答更准确,我们需要存储用户和机器人的聊天记录,并在查询时调用这些记录,可以用…

新版校园跑腿独立版小程序源码 多校版本,多模块,适合跑腿,外卖,表白,二手,快递等校园服务

最新校园跑腿小程序源码 多校版本&#xff0c;多模块&#xff0c;适合跑腿&#xff0c;外卖&#xff0c;表白&#xff0c;二手&#xff0c;快递等校园服务 此版本为独立版本&#xff0c;不需要** 直接放入就可以 需要自己准备好后台的服务器&#xff0c;已认证的小程序&#xf…

mysql面试题17:MySQL引擎InnoDB与MyISAM的区别

该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 面试官:MySQL引擎InnoDB与MyISAM的区别 InnoDB和MyISAM是MySQL中两种常见的存储引擎,它们在功能和性能方面有一些区别。下面将详细介绍它们之间的差异。…