Java的数据类型
1、数据是怎么储存的?
- 数据是以二进制的方式储存在电脑中,存在基本数据类型和引用数据类型两种数据类型,基本数据类型是声明的变量在内存中的位置就是储存数据的位置,例如:int a = 1,则意味着在电脑中开辟了四个字节储存数据,0000 0000 0000 0001。(若声明int a = 01,则是以八进制表示的数据;int a = 0x11,是以十六进制表示的数据)
-
引用数据类型在内存中的位置存储的实际上是数据在内存中存放的地址,当需要用到引用数据类型的数据时,则根据地址取数据。例如:引用数据类型 String s = “ ”,s是一个存储“ ”的内存空间的地址,” ”(空格)以ASCALL码的形式存储,需要使用时,可以通过地址s找到数据,可以找到类声明的都是引用数据类型。(另,以' ' 单引号声明的是字符,以“ ” 双引号声明的才是字符串。
2、类型转换和类型提升
低精度转换成高精度直接转换,高精度转到低精度会造成精度损失,例如:整数除法是地板除,向下取整。类型转换是小范围向大范围转换,大范围向小范围转换需要使用强制类型转换。例如:
- int a=12; double b=a;
- double a=3.0; int b=(int)a;
强制类型转换可能会导致数据丢失精度。
3、基本数据类型对应的装箱数据类型
每一个基本数据类型都会有一个对应的装箱数据类型
基本数据类型的封装类:
数据类型 封装类
boolean(布尔型)Boolean
byte(字节型)Byte
char(字符型)Character
short(短整型)Short
int(整型)Integer
long(长整型)Long
float(浮点型) Float
double(双精度浮点型) Double
- 为什么需要装箱数据类型?
1、容器类不接受原⽣数据类型
2、可以赋值为null
3、提供额外的⽅法
4、 ⾃动装箱与拆箱
装箱类型有助于List或ArrayList操作,容器中只接收引用类型的数据。
装箱类型提供额外的方法,例如:equals(),paseInt()
Integer之间判断相等只能使用equals(),a.equals(b)因为Integer声明的是对象,存储的是实际实际数字的地址,不能直接用==判断,Integer本身是不可变的,Integer没有提供修改的方法。当Integer对象存储的数字较小时,会使用IntegerCache缓存,从而存储较小数字的都是同一对象,减小系统压力。
对此,有以下代码:
public static void main(String[] args) {
Integer a = 1;
Integer b = 1;
System.out.println(a==b);
Integer c = 200;
Integer d = 200;
System.out.println(c==d);
}
输出为:
true
false
在配置了high的值(例如1000)后输出都为true.
因为a和b在[-128,127]之间,引用的是同一个对象,所以相等。
而c和d虽然值都为200,但是在配置high的值前不在[-128~127]之间,是两个完全不同的对象,所以不相等。
装箱
以Integer为例。
将基本数据类型变为包装类,例如
Integer i = 2;
拆箱
将包装类变为基本数据类型,例如
Integer i = 2;
int j = i;
PS:浮点数是不精确的,只能比较大小不能比较相等,不能用 == 做等于判断,要用Math.abs(a – 2.0)< 0.0000001(小于一个极小的数),可以认为它们相等
声明一个long型变量,long c = 22_0000_0000L
声明一个float型变量,float c = 0.0f
声明一个double型变量,double c = 0.0d (也可以使用科学计数法 例如:1e-7 一乘以十的负7次方
Idea查看类中方法和成员变量时默认快捷键为CTRL+F12
基本数据类型的包装类在拆箱时可能会引发空指针异常,需要处理。