Java中int的表示方法及其作用

在Java中,int是使用32位表示,long使用64位表示。这两个基本类型都是整形,没有其他的表示方法了。他们内部是怎么表示的呢?是采用补码表示。由于我们经常在做题中会遇到Java的位运算,Java的位运算只能用于int和long型。所以我们有理由好好分析Java内部是怎么用二进制表示的。这里只举int为例子,long是一样的。

1、int的范围

int在Java内部是用32位来表示的,而最高位是表示符号,因此真正可以表示数字的是31位。Java的int类型取值范围是-2^31~2^31-1.

2、为什么范围是这样?这就涉及到二进制的存储方法了。

在Java中,是使用补码来存储int。对于一个正数,其补码,就是本身。例如,我们举4个位来做例子。对于正数1-7,分别是0001,0010,。。。,0111,一共是7个数字,也就是2^3-1个。

对于0,可以看到问题来了。可以是-0,也可以是+0,都是0。决定要怎么表示0呢?补码的法则规定,0认为是+0,因此0用0000表示。

这个时候,需要表示负数了。我们认为,一个负数,它的补码表示是其绝对值取反(连同符号位一起取反)再加1。例如,对于-5,它的绝对值是5,表示为0101,取反,为1010,加一为1011,这就是-5的补码表示。

这个时候,可以用1000来表示-8,于是负数的范围是-2^31,这也就解释了int的取值范围。对于64位的long也是完全一样的。

2、Java的位运算

Java的位运算是怎么做的呢?要记住,移位运算是整个数整体向左或者右移动。如果是向左移,则是低位补0。如果是向右移,分两种情况。如果是0和正数,则高位补0。如果是负数,则高位补1。如对于-5为1011,右移一位为1101,也就是-3。

还有一种位运算。如果是按位运算,记得符号位也是要参与进来的!

3、右移与除法的关系

对于正数(当然0也是)来说,右移一位等于除以2的结果,但是对于负数来说不是(确切地说是除以2的结果-1)!例如,-5/2结果是-2,-5>>1结果是-3。

4、正负号与整数除法、取余运算的关系

正数/正数,向下取整

负数/负数,等于他们的绝对值相除

正数/负数和负数/正数,就是他们绝对值相除乘上负号。

至于%的结果,结果的绝对值与他们绝对值的取余一样,但是符号由第一个数决定。

5、为什么要用补码?

(1)前面已经说过,为了合理地表示+0和-0;

(2)可以在负数处多表示一个最负的数;

(3)使用补码,可以将符号位和其它位统一处理;同时,减法也可按加法来处理。另外,两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。

其实很大一个原因是为了计算加减法方便。在使用补码系统进行运算的时候,是可以把符号位加起来一起运算的。在位运算中,如果符号位有进位,是可以舍弃的,因为已经超出了比特范围了。对于正数和正数相加,没什么特别的。下面例子都是8个比特的。例如,对于7+7,也就是00000111+00000111,结果是00001110,为14。

而对于减法,例如9-4,我们就认为是9+(-4),先对4,也就是00000100取反再加一,得到-4的补码表示11111100,然后相加,也就是

+00001001(9)

+11111100(-4)

_____________

  100000101

最后一位符号位的进位1,因为已经超出了比特范围,所以直接舍弃,可以直接就得到5了。所以这也就是实现了减法变加法。











  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当我们需要在代码表示一组固定的值时,可以使用Java的枚举类。枚举类是一种特殊的类,用于定义一组有限的常量。它提供了更好的可读性和类型安全性。 以下是创建和使用枚举类的步骤: 1. 定义枚举类:使用关键字`enum`来定义一个枚举类,后面跟着枚举类的名称。 ```java enum Day { MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY } ``` 2. 声明枚举实例:在枚举类定义的常量被称为枚举实例。它们通常以大写字母表示,并以逗号分隔。 3. 使用枚举实例:可以像使用其他类型的变量一样使用枚举实例。例如,通过将枚举实例赋值给变量,或者作为方法的参数或返回值。 ```java Day today = Day.MONDAY; System.out.println("Today is " + today); ``` 4. 枚举方法:枚举类可以包含方法和构造函数。可以为枚举实例添加自定义方法,并在枚举类定义其他行为。 ```java enum Day { MONDAY("Monday", 1), TUESDAY("Tuesday", 2), // ... private String name; private int value; private Day(String name, int value) { this.name = name; this.value = value; } public String getName() { return name; } public int getValue() { return value; } } ``` 在上面的示例,我们为每个枚举实例添加了名称和值,并定义了构造函数和方法来获取它们的值。 枚举类的优点包括: - 类型安全性:只能使用枚举实例定义的值,不允许使用任意其他值。 - 可读性:枚举实例以清晰的方式表示,使代码更易于理解和维护。 - 扩展性:可以为枚举实例添加新的属性和行为。 希望这个详细解释能帮助你理解Java的枚举类及其使用方法。如果你还有其他问题,请随时提问!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值