也谈c语言int类型最小值

c语言中int是带符号的32位数,最高位为符号位,其余31位为数值位,最大的int值很好算,那就是符号位为0,其余31位全为1,那么这个值就等于231-1,这个没有异议。
那么int类型的最小值就比较绕了,因为这个值是一个负数,而负数在计算机里是用补码来表示的,也就是用负数的绝对值,按位取反,再加1得到补码。

之前在网上找过很多文章,大都语焉不详,自己验证了详细的过程以后把心得写下来。

补码完整步骤:

  1. 确定负数的绝对值,也就是一个正数
  2. 对这个正数写成二进制形式,并按位取反
  3. 加1得到补码

用-1来举例说明这个过程:

  1. 确定-1的绝对值,是1
  2. 写成二进制形式,是000000000000.....1,取反后得到1111111111111......0
  3. 加1得到111111111111111......1

因此-1的补码形式是32位全为1的数,也就是0xFFFFFFFF

确定int类型的最小值的过程是上面过程的逆过程,我们要把上面步骤反过来,先确定这个最小值的补码,然后再确定对应的十进制是多少。

注意负数的补码可以直接参与运算

还以上面-1的例子继续举例,我们先运算-1-1=-2,然后看看倒推回去看看绝对值是不是2

  1. 对-1的补码-1,得到111111111111111......0,这就是-2的补码
  2. 对这个补码-1,得到111111111111111.....01
  3. 按位取反,得到0000000000000000......10,这正是-2的绝对值2

有了这些基础,现在我们就可以来确定int的最小值了。我们先确定它的补码形式,既然是最小的int,也就是不能再-1了,再-1之后就会发生向更高的数值位借位的情况,因此可以唯一确定补码为1000000000000......0
最高为1,表示负数,后面31个数值位全为0,此时再-1就会发生向符号位更高位借位的情况,因此这就是最小值了。
现在来倒推去掉补码之后的绝对值是多少:

  1. 对补码-1,得到0111111111111111......1
  2. 按位取反,得到10000000000000......0

得到的二进制位与补码一样,这是一个巧合。
现在这个100000000000......0表示这个最小int的绝对值,也就是一个正数,因此最高为1不能再表示符号位了,那么绝对值是231,因此最小值是-231
由此得到32位有符号数的取值范围为-231到231-1

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1、标识符 什么事标识符呢?变量的名字就是标识符。不仅限于变量名,程序中各种元素的名字,都属于标识符。例如符号常量...
    滕王阁序阅读 4,592评论 0 0
  • https://www.jianshu.com/p/55a8195291db本篇文章讲解了计算机的原码, 反码和补...
    PupilCHen阅读 4,944评论 1 48
  • 结论,取值范围是-2^31~2^31-1(十六进制为0x80000000~0x7fffffff)。因为0既不是正数...
    隔壁老王1995阅读 10,097评论 0 0
  • 1.从生活、常识、用户方面思考问题(多) 从理论、知识、哲学方面思考问题(少) 2.看起来困难的事只要认真对待就不...
    sessos阅读 2,144评论 0 1
  • 我不清楚我是个怎么样的人 我只知道我一直在努力做一个比较善良的人 我希望人们在提到我的时候没有显而易见的讨厌
    苏宿素阅读 1,076评论 0 0

友情链接更多精彩内容