关于unsigned char、unsigned short使用printf(“%d”)进行输出的结果

参考博客:C语言 unsigned 和 signed 类型相互转换深入理解

参考博客:unsigned和signed

对于unsigned 无符号数据类型是不应该向其赋值负数的,但是如果赋值了那会怎么样呢?

#include <stdio.h>
#include <stdlib.h>
int main()
{
	unsigned char uc= -1;
	unsigned short us=-1;
	unsigned int ui= -1;
	printf("uc=%d\n",uc);
	printf("us=%d\n",us);
	printf("ui=%d\n",ui);
	system("pause");
	return 0;
}

运行结果如下:


产生这种结果的原因是什么?uc和us在使用printf函数进行输出时都会进行类型提升,补足为4字节的int 类型(这么说可能不严谨,反正就是提升为4字节),由于uc和us都是无符号类型,所以提升的时候前面都是补0。也就是说us在内存中的存储形式是0x0000ffff,uc在内存中是0x000000ff,而ui在内存中是0xffffffff,printf函数输出什么值是和前面的数据类型符相关的,例如上面那段程序中的printf是%d,那么编译程序就按照有符号整数来对后面的变量进行解释。

相同赋值的int和usigned int在内存中的表示是一样的,signed和unsigned只是告诉程序对内存的不同解释方式,前者按照有符号数解释(考虑符号位),后者按无符号数(不考虑符号位)解释,这一点和%d,%u的作用是一样的。

%d,%u的不同就在于对内存的解释不同,前者将内存中的数据看成有符号的,后者看成是无符号的。(将signed int使用%u输出,实质就是相当于对这块内存的重新解释)。变量的输出与变量是unsigned还是unsigned无关,而取决于%d或u%等对内存的再解释

有符号类型(char)无论向有符号类型(int)还是无符号类型(unsigned int)扩展,都会按照有符号数的扩展规则(高位补符号位)。
无符号类型(unsigned char)无论向有符号类型(int)还是无符号类型(unsigned int)扩展,都会按照无符号数的扩展规则(高位补0)。

补充一张图,确实发生了类型提升


  • 14
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值