也谈c语言int类型最小值

 我来答
天罗网17
2022-06-09 · TA获得超过6200个赞
知道小有建树答主
回答量:306
采纳率:100%
帮助的人:73.8万
展开全部

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

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

补码完整步骤:

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

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

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

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

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

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

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式