加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Windows > 正文

为什么uint8_t和uint16_t的格式说明符相同(%u)?

发布时间:2020-12-14 04:11:10 所属栏目:Windows 来源:网络整理
导读:参见英文答案 What default promotions of types are there in the variadic arguments list?1个 由于搜索printf()的结果很多,我只发现了相关的问题. 为什么uint8_t没有指定自己的格式字符串,但是其他类型呢? 据我所知,printf(),它必须知道提供的参数的长度
参见英文答案 > What default promotions of types are there in the variadic arguments list?1个
由于搜索printf()的结果很多,我只发现了相关的问题.

为什么uint8_t没有指定自己的格式字符串,但是其他类型呢?

据我所知,printf(),它必须知道提供的参数的长度,以便能够解析变量参数列表.

由于uint8_t和uint16_t使用相同的格式说明符%u,printf()如何“知道”要处理多少字节?或者在提供uint8_t时是否以某种方式对uint16_t进行了隐式转换?

也许我错过了一些明显的东西.

printf()是一个可变函数.它的可选参数(只有那些)根据默认参数提升(6.5.2.2.p6)得到提升.

由于要求整数,因此在这种情况下应用整数提升,并且您提到的类型将被提升为int. (而不是unsigned int因为C)

如果在printf()中使用“%u”,并将其传递给uint16_t变量,则该函数将其转换为int,然后转换为unsigned int(因为您使用%u请求它)然后将其打印出来.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读