char型变量的运算中,signed和unsigned的运算分析

signed和unsigned的运算分析

前几天碰到了一个例子很有意思,加深了对源码,反码,补码的认识,例子如下:

int main()
{
	//signed时,char 最高位为符号为,其余为数据位
    char x1 = 255;  // 1111 1111(最高位为符号位)
    char x2 = 256;  // 1 0000 0000 (数据溢出的位数舍弃)
    int x3 = x1 +x2;
    printf("signed:%d\n",x3);


	//unsigned时,8位二进制数都为数据位,最大值为255
    unsigned char y1 = 255;
    unsigned char y2 = 256;//1 0000 0000 舍弃超出的一位
    unsigned int y3 = y1 + y2;
    printf("unsigned:%d",y3);

}

输出结果:
在这里插入图片描述

分析其结果原因:
对于一个变量的二进制值的最高位为1的,
如果该变量的数据类型是有符号的(signed),则该二进制值必然都是一个补码值

如果该变量的数据类型是无符号的(unsigned),则该二进制值必然都是一个原码值

计算过程如下图:

在这里插入图片描述

了解更多,看看其他博客吧

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值