1.在不同的系统下,各种类型的字节也不同,如下图所示:
2.格式控制符和整数的符号是紧密相关的,具体如下:
- %d 以十进制形式输出有符号数;
- %u 以十进制形式输出无符号数;
- %o 以八进制形式输出无符号数;
- %x 以十六进制形式输出无符号数。
如何以八进制和十六进制形式输出有符号数呢?
printf 并不支持,也没有对应的格式控制符。在实际开发中,也基本没有“输出负的八进制数或者十六进制数”这样的需求,我想可能正是因为这一点,printf 才没有提供对应的格式控制符。
下表全面地总结了不同类型的整数,以不同进制的形式输出时对应的格式控制符:
|
short |
int |
long |
unsigned short |
unsigned int |
unsigned long | |
|
八进制 |
-- |
-- |
-- |
%ho |
%o |
%lo |
|
十进制 |
%hd |
%d |
%ld |
%hu |
%u |
%lu |
|
十六进制 |
-- |
-- |
-- |
%hx 或者 %hX |
%x 或者 %X |
%lx 或者 %lX |
%o 和 %x 来输出有符号数了,为什么没有发生错误呢?
- 当以有符号数的形式输出时,printf 会读取数字所占用的内存,并把最高位作为符号位,把剩下的内存作为数值位;
- 当以无符号数的形式输出时,printf 也会读取数字所占用的内存,并把所有的内存都作为数值位对待。
对于一个有符号的正数,它的符号位是 0,当按照无符号数的形式读取时,符号位就变成了数值位,但是该位恰好是 0 而不是 1,所以对数值不会产生影响,这就好比在一个数字前面加 0,有多少个 0 都不会影响数字的值。
3.运算符优先级,具体如下:

这篇博客讨论了在不同系统下字节的差异,并详细介绍了printf函数中格式控制符的使用,特别是针对整数的%d, %u, %o, %x等。虽然printf不支持直接以八进制或十六进制形式输出有符号数,但解释了为何可以以无符号形式输出有符号数而不会出错,这涉及到内存读取和符号位的处理。同时,文章还提及了运算符的优先级,这对于理解代码执行顺序至关重要。
1400

被折叠的 条评论
为什么被折叠?



