java int范围_Java之int及它的取值范围

本文详细解读了Java中int类型的存储容量(4字节),取值范围(-2^31到2^31-1),以及其在内存中的补码表示方式。通过实例演示了如何理解Math.abs()操作在int值上的应用,揭示了负数补码的计算过程。重点讲解了计算机如何存储和处理负数,以及为何int的最大值加1会变成最小值。
摘要由CSDN通过智能技术生成

int是Java中的8种基本类型之一,一个int值占4个byte(8个二进制位)

8中基本类型所占字节分别是多少: int4个字节

2个字节

long字节

2个字节

float4个字节

double8个字节

boolean 没有提供size的方法

思考:一个int,它的取值范围是多少呢?在内存中又是怎么存储的呢?

答案:它的取值范围是:【-2的31次方(-2147483648),2的31次方减一(2147483647)】,它在内存中是以补码(对应正数的二进制位取反,加1)的形式存储的

先上代码,通过下面代码的执行结果观察

运行结果:

j的值2147483647

继续修改代码

运行结果(同上面代码):

j的值2147483647

再次修改代码

运行结果:

j的值-2147483648

这里是负值,int型最小值

当int的最大值+1后,会变成int的最小值

故:java中int的取值范围是2的32次方,最大值是2的31次方,最小值是负值的2的31次方-1

首先要明确两个概念:(1)一个数在计算机中存储的是它的补码。

(2)Math.abs(a)中的-a对应计算机在内部的操作是:将a在计算机中的存储值(a的补码)所有位(32位)取反之后加1。

因此,-128在计算机中存储的是它的补码(它对应的正数的所有位取反+1):

128用二进制表示是:00000000 00000000 00000000 10000000

128所有位取反是:11111111 11111111 11111111 01111111

加1之后是:11111111 11111111 11111111 10000000(这个就是-128在计算机中存储的值(补码))

如果我们调用Math.abs(-128),机器会怎么做呢?

首先,取反:00000000 00000000 00000000 01111111

加一:00000000 00000000 00000000 10000000(128)

因此Math.abs(-128)的结果就是128.

同理,Math.abs(-2147483648)也是这样的操作:

-2147483648在计算机中存储的值是:10000000 00000000 00000000 00000000

Math.abs(-2147483648)中 -a操作,首先取反:01111111 11111111 11111111 11111111

然后加一:10000000 00000000 00000000 00000000

而上面这个数,计算机识别为-2147483648

补充知识:

对于正数来说,它的补码就是它本身。

对于负数来说,它的补码是它对应的正数的二进数所有位取反之后加一。

由负数的补码求原码也是相同的操作(所有位取反+1)即为该负数的绝对值

int是4个字节,32位,

对剩下的位取反,结果为 1111111 11111111 11111111 11111111,加一后为10000000 00000000 00000000 00000000

所以原码指的是-2^31=-2147483648

int的取值范围为-2^31――2^31-1

在计算机中,负数的补码为:正值二进制取反+1。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值