Integer.MIN_VALUE和Integer.MAX_VALUE

java源代码:
Integer.MAX_VALUE经常会在集合中用到,对这个概念一直没有深究过,查看一下源码。
一个常数,持有了int类型数最小值,-2^31次方,-2147483648。负21亿多。
/**

  • A constant holding the minimum value an {@code int} can
  • have, -231.
    */
    @Native public static final int MIN_VALUE = 0x80000000;

一个常数,持有了int类型数的最大值,2^31次方,2147483648,正21亿多
/**

  • A constant holding the maximum value an {@code int} can
  • have, 231-1.
    */
    @Native public static final int MAX_VALUE = 0x7fffffff;

解释:
1、0x80000000
0x表示16进制
80000000一共8位16进制,也就是32位的2进制,2进制写法位数太多了,不展开写了,这也是为什么用16进制表示的原因。
1000 后面28个0,前面1表示负数,后面的27个0,这个应该是补码,那就是-1,会得到27个1,然后再求反码,27个0,纳尼???
因为这个数达到了32位二进制的上限,所以我们不会再去按照-1,再反码的方式求真正的值,直接按照原码的负数计算即可。也就是-2^31次方。

2、0x7fffffff
展开就是0111后面28个1,也就是一共31个1的整数,2^31 - 1

3、MAX_VALUE + 1 == MIN_VALUE
这他妈就好玩了,0111 1111 1111 1111 1111 1111 1111 1111+1 = 1000 0000 0000 0000 0000 0000 0000 0000 没毛病。
或者这么想,我们把计算的“模”从中间剖开,负数逆时针,正数顺时针,正方向从0到6点钟,包括0不包括6点钟,负方向从0到6点钟,不包括0,包括点钟,MAX_VALUE前面一个数就是MIN_VALUE

4、int型的最大值+1溢出后等于-214783648。二进制系统是通过补码来保存数据的。第一位是符号位,0为正,1为负,当正的除了符号位全为1,再加1就进位了,符号位就会变成1,是负数,其他为0。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值