整型截断和整型提升

  我们先来关注几个问题。

   1、为什么会有整型的截断和整型的提升;

   2、什么是整型的截断和整型的提升;

第一个问题提升在计算机处理的时候不够一个整型的数据会提升至一个int 整型来处理,而截断时发生在打印数据的时候,或者比较数值大小的时候。在cpu处理时提升至in型而打印的时候会将其截断变为一个字节数据

第二个问题,打个比方 char  a = -12,假如是16位的二进制数,cpu处理时 1000000000001100,由于char 的类型大小是一个字节,在打印时会发生截断,只打印前八位数(有符号的打印),有人会问前八位是00001100那岂不是变成正数?非也,上面的1000000000001100只是个原码,而截断时候是在补码的时候截断的,同时提升也是在补码的时候提升的。正确的应该是这样:

原码 10001100

反码 11110011

补码 11110100

(算术)提升后变成 1111111111110100

由于要打印所以再截断

补码:11110100

原码:10001011

所以十进制是-12;

这样说比较笼统 只是大概了解

我们来看一道题

int main()
{
  unsigned char a = 200;
  unsigned char b = 100;
  unsigned char c = 0;
  c = a + b;
  printf(“%d %d”, a+b,c);
  return 0;
}

首先看a

原码1100 1000(无符号)

补码1100  1000(正数原反补都一样)

同理 b的补码为 0110 0100

在进行a+b时cpu会对a和b的数据进行提升

a变成0000000011001000(假设时16位)

b变成0000000001100100

相加变成0000000100101100(300(b))

前面说了a+b会整型提升为整型

所以a+b=300

c在cpu中时是0000000100101100

但会发生截断变成00101100(0b44)(这里是补码 要转化为原码 要看它的类型 类型是unsigned char)

所以原反补都一样

所以打印c=44;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值