INT_MAX INT_MIN及其运算

文章解释了C++中INT_MAX和INT_MIN的定义,指出INT_MAX为2^31-1,INT_MIN为-2^31-1,由于整数溢出,不能直接用-2147483648表示最小负整数。文章以八位整数为例说明有符号整数的表示范围,强调了补码在表示负数中的作用。
摘要由CSDN通过智能技术生成

        C++中常量INT_MAX和INT_MIN分别表示最大、最小整数,定义在头文件limits.h中。

#define INT_MAX 2147483647
#define INT_MIN (-INT_MAX - 1)

        因为int占4字节32位,根据二进制编码的规则:

INT_MAX = 2^31-1,INT_MIN= -2^31.

        在C/C++语言中,不能够直接使用-2147483648来代替最小负数,因为这不是一个数字,而是一个表达式。意思是对整数21473648取负,但是2147483648已经溢出了int的上限,所以定义 INT_MIN(-INT_MAX -1)


思考:

上溢是2147483647很容易理解,2147483647=2^31-1 (因为要有一个符号位,所以把第一位作为符号位,0为正,1为负),但为什么下溢的时候分明是31位来表示的数会出现2147483648呢??

我们以八位整数为例:
        00000000~01111111, 表示0~127。10000001到11111111,表示-1到-127。大家可以注意到,10000000我们没有用到。因为如果我们把它看成-0,那么会和00000000发生重复。于是计算机将10000000定义为-128(即在最终进位后符号位不产生进位)。

        (1) 对于无符号n位整数,表示范围很好理解[0 ~ 2^n−1];

        (2)(2) n位有符号整数的表示范围为[−2^(n−1) ~ 2^(n−1)−1],对于有符号整数,计算机使用补码表示。具体见《反补码运算之 “1 - 1 = - 1 ” ?》

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值