java.lang.Integer.MAX_VALUE; 0x7FFFFFFF;0x80000000;java.lang.Integer.MIN_VALUE这是什么意思?

在Java中,一共有8种基本数据类型:

整数型:int , short , long , byte 。
浮点型:float , double 。
字符类型:char 。
表示真值的类型:boolean 。

(String属于Java中的字符串类型,也是一个引用类型,并不属于基本的数据类型)

整数型和浮点型取值范围如下:

在这里插入图片描述
Integer.MAX_VALUE表示int数据类型的最大取值数:2 147 483 647
Integer.MIN_VALUE表示int数据类型的最小取值数:-2 147 483 648

对应:
** Short.MAX_VALUE 为short类型的最大取值数 32 767
Short.MIN_VALUE 为short类型的最小取值数 -32 768**

其他数据类型同上含义

这个是Integer类中的一个int类型的常量MAX_VALUE
它代表int所能表示的最大值 0x7FFFFFFF

相对应的是Integer类中的另一个常量MIN_VALUE
它代表int所能表示的最小值 0x80000000

 

整型的其他的子型也可以 byte short long?

基本类型之间不存在子型和父型,只是范围不同,
小范围转换为大范围可以直接转换
大范围转换小范围需要强制转换符号,
例如:
 long lv=123456;
int v=(int) lv;
 
数字基本类型都有对应的类及最大最小值常量
Byte.MAX_VALUE =0x7F
Byte.MIN_VALUE  =0x80
 
Short.MAX_VALUE =0x7FFF
Short.MIN_VALUE  =0x8000
 
Integer.MAX_VALUE =0x7FFFFFFF
Integer.MIN_VALUE  =0x80000000
 
Long.MAX_VALUE =0x7FFFFFFFFFFFFFFF
Long.MIN_VALUE  =0x80000000000000000

java源代码:
Integer.MAX_VALUE经常会在集合中用到,对这个概念一直没有深究过,查看一下源码。

一个常数,持有了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

 

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




Integer.MIN_VALUE,即-2147483648,二进制位如下: 

 
1000 0000 0000 0000 0000 0000 0000 0000 

 

在计算机的运算中,“-”(前缀)运算表示各二制位取反再加1,也就是说 b = -a 在计算机内部是 b = ~a + 1 这样处理的,所以上面的位就变成了: 

 

   1000 0000 0000 0000 0000 0000 0000 0000 Integer.MIN_VALUE 

取反 0111 1111 1111 1111 1111 1111 1111 1111 (取反之后变成了Integer.MAX_VALUE) 

加1 1000 0000 0000 0000 0000 0000 0000 0000 -Integer.MIN_VALUE(与原来的结果一样)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风水道人

写作不易且行且珍惜

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值