计算实现思路如下:
jdk中定义int占4个字节 ===> 32位(后面全部的计算都是以此为根据的)32位就是jvm仅仅给分配32个格子的空间,用以存放数据。
而计算机中用0和1存放数据。那么,32个格子中放满0或1的方法就有2的32次方种。所以,这32个格子中。或者说32位的空间能标识10进制的数字:
1、最小:
2、最大:
第一种推算法:将二进制最大的数字(32个1)转换成10进制,即 4294967296;
另外一种推算法:既然有2的32次方种算法,那么依照10进制最大的数就是2的32次方。即4294967296。
不过,这样的计算的是无符号。即正数。可是java中int有正负之分。所以32个格子中占用一个格子标识正负。所以仅仅能用31个格子来标识数值:
其中,x为0、1来标识正负。
即最后int能标识的最大/最小数字是:2的31次方:+/- 2147483648。
扩展资料:
java中各数据类型的取值范围:
1、int。
最小值:Integer.MIN_VALUE= -2147483648 (-2的31次方)
最大值:Integer.MAX_VALUE= 2147483647 (2的31次方-1)
2、short。
最小值:Short.MIN_VALUE=-32768 (-2的15此方)
最大值:Short.MAX_VALUE=32767 (2的15次方-1)
3、long。
最小值:Long.MIN_VALUE=-9223372036854775808 (-2的63次方)
最大值:Long.MAX_VALUE=9223372036854775807 (2的63次方-1)
4、float 。
最小值:Float.MIN_VALUE=1.4E-45 (2的-149次方)
最大值:Float.MAX_VALUE=3.4028235E38 (2的128次方-1)
5、double。
最小值:Double.MIN_VALUE=4.9E-324 (2的-1074次方)
最大值:Double.MAX_VALUE=1.7976931348623157E308 (2的1024次方-1)
参考资料: