关于有符号整型int最小值的取值理解

1. 在计算机系统中,数值一律用补码来存储。原因如下:

- 统一了零的编码
- 将符号位和其它统一处理。
- 将减法运算转变为加法运算。
- 两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。

2. 对于有符号正整数,原码、反码和补码一样。

3. 对于有符号负整数

最小值:1000 0000 0000 0000 0000 0000 0000 0000
注意:对于计算机来说,它并不认识负数是什么。对于它来说,最小数是0,最小数的符号位肯定是负数。所以在计算机的眼中,最小的有符号的整数一定是:1(符号位)+0000… 而且这个数是补码形式。

4.推出有符号负整数的最小值

假设:1111 1111 1111 1111 1111 1111 1111 1111 是有符号负整数的最小值。(为什么要这么假设?按照人类的思维,负号后面的数越大,则该数越小。)
原码:1111 1111 1111 1111 1111 1111 1111 1111 ==》 -2147483647(十进制表示)
反码:1000 0000 0000 0000 0000 0000 0000 0000
补码:1000 0000 0000 0000 0000 0000 0000 0001
补码还可以-1,所以可以退出有符号负整数的最小值是-2147483648即-2^32

4.对于有符号整型int最小值的取值理解

已知补码: 1000 0000 0000 0000 0000 0000 0000 0000 ==> -0 0000(补码符号位不变,取反,加1,可得该补码的原码。)
求得原码:1 0000 0000 0000 0000 0000 0000 0000 0000
由于整型的大小是4个字节,一共32位,所以进位1,属于数值溢出,舍去。那么求得原码为:0000 0000 0000 0000 0000 0000 0000 0000(该原码的十进制为0)
那么问题就来了,为什么由-0求得的补码,再由求得的补码反求出的原码不一样呢?
根据部分书中的解释,计算机系统中存储的1000 0000 0000 0000 0000 0000 0000 0000(对于计算机来说,它没有补码、原码的概念。)是没有原码的。1000 0000 0000 0000 0000 0000 0000 0000 的值等于-2147483648,等于-0的值。这个可以理解为规定。


总结:int型的取值范围:-2147483648 - 2147483647
  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值