java中的int的取值范围如何计算???

2020-05-04 科技 185阅读

计算实现思路如下:

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)

参考资料:

百度百科--数据类型

声明:你问我答网所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流。若您的权利被侵害,请联系fangmu6661024@163.com