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

前端之家收集整理的这篇文章主要介绍了为什么uint8_t和uint16_t的格式说明符相同(%u)?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
参见英文答案 > 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请求它)然后将其打印出来.

猜你在找的Windows相关文章