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,包括6点钟,MAX_VALUE再往前+1,就是MIN_VALUE

 

 

 

你可能感兴趣的:(Java通用知识,Java集合类源码解读)