在JDK中,整形类型是有范围的,最大值为Integer.MAX_VALUE,即2147483647,最小值为Integer.MIN_VALUE -2147483648。
在JDK中,整型类型是有范围的 -2147483648~2147483647 ( -2^31 --- 2^31-1)
一个常数,持有了int类型数最小值,-2^31次方,-2147483648。负21亿多。
/**
* A constant holding the minimum value an {@code int} can
* have, -2<sup>31</sup>.
*/
@Native public static final int MIN_VALUE = 0x80000000;
一个常数,持有了int类型数的最大值,2^31次方,2147483648,正21亿多
/**
* A constant holding the maximum value an {@code int} can
* have, 2<sup>31</sup>-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
在JDK中,整形类型是有范围的,最大值为Integer.MAX_VALUE,即2147483647,最小值为Integer.MIN_VALUE -2147483648。
对整形最大值加1,2147483648(越界了),那么此时值为多少呢?结果是-2147483648,即是Integer.MIN_VALUE。
类似的,对Integer.MIN_VALUE取反或者取绝对值呢?仍为Integer.MIN_VALUE,因为值为-2147483648,绝对值2147483648超过Integer.MAX_VALUE 2147483647。
所以就有以下结果
Integer.MAX_VALUE + 1 = Integer.MIN_VALUE
Math.abs(Integer.MIN_VALUE) = Integer.MIN_VALUE (绝对值)
Long,short,byte的结论是相同的。
Integer.MIN_VALUE - 1 = Integer.MAX_VALUE
Integer.MAX_VALUE + 1 = Integer.MIN_VALUE
-Integer.MIN_VALUE = Integer.MIN_VALUE
-Integer.MAX_VALUE = Integer.MIN_VALUE + 1