数据类型
【一】简介
变量就是申请内存来存储值。也就是说,当创建变量的时候,需要在内存中申请空间。
内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据
Java 的两大数据类型:
1、内置数据类型
2、引用数据类型
【二】java的8大基本数据类型
基本数据类型是CPU可以直接进行运算的类型。Java定义了以下几种基本数据类型:
1、整数类型:byte,short,int,long
2、浮点数类型:float,double
3、字符类型:char
4、布尔类型:boolean
计算机内存的最小存储单元是字节(byte),一个字节就是一个8位二进制数,即8个bit。它的二进制表示范围从0000000011111111,换算成十进制是0255
ps:基本数据类型一般是在java虚拟机栈上进行分配的内存,一般是对应程序中的局部变量
【三】java的引用数据类型
- 在Java中,引用类型的变量非常类似于C/C++的指针。引用类型指向一个对象,指向对象的变量是引用变量。这些变量在声明时被指定为一个特定的类型,比如 Employee、Puppy 等。变量一旦声明后,类型就不能被改变了。
- 对象、数组都是引用数据类型。
- 所有引用类型的默认值都是null
ps:对于引用变量一般是在java堆中进行分配的内存
【四】java常量
常量在程序运行时是不能被修改的。
在 Java 中使用 final 关键字来修饰常量,声明方式和变量类似。
final double PI = 3.1415927;
ps:常量是分配在java方法区中的常量池中,是不允许进行修改值的
【五】类型转换
-
整型、实型(常量)、字符型数据可以混合运算。运算中,不同类型的数据先转化为同一类型,然后进行运算。
-
转换从低级到高级
1. 不能对boolean类型进行类型转换。
2. 不能把对象类型转换成不相关类的对象。
3. 在把容量大的类型转换为容量小的类型时必须使用强制类型转换。
4. 转换过程中可能导致溢出或损失精度
5. 浮点数到整数的转换是通过舍弃小数得到,而不是四舍五入
自动类型转换
满足低位向高位转换,比如:
byte b = 1;
int a = b;
对于低位是可以自动进行转换为高位
强制类型转换
1、 条件是转换的数据类型必须是兼容的
2、 高位转低位
比如:
int a = 1;
byte b = (byte)a;
ps:在我们平时代码的过程中,默认整数是int,浮点double
使用long的时候需要在后面加L
使用float的时候需要在后面加F
【六】面试题
- 1.1 short s1 = 1; s1 = s1 + 1;有什么错?
答:在s1+1运算时会自动提升表达式的类型为int,那么将int赋予给short类型的变量s1会出现类型转换错误。
- 1.2 char类型变量能不能储存一个中文的汉子,为什么?
答:char类型变量是用来储存Unicode编码的字符的,unicode字符集包含了汉字,所以char类型当然可以存储汉字的,还有一种特殊情况就是某个生僻字没有包含在
- 1.3 Integer和int的区别
答:int是java的8种内置的原始数据类型。Java为每个原始类型都提供了一个封装类,Integer就是int的封装类,int变量的默认值为0,Integer变量的默认值为null
- 1.4 能否在不进行强制转换的情况下将一个 double 值赋值给 long 类型的变量?
答:不行,我们不能在没有强制类型转换的前提下将一个 double 值赋值给 long 类型的变量,因为 double 类型的范围比 long 类型更广,所以必须要进行强制转换。
- 1.5 java 中 3*0.1 == 0.3 将会返回什么?true 还是 false?
答:false,因为浮点数不能完全精确的表示出来,一般都会损失精度
- 1.6 java 中 float f = 3.4; 是否正确?
答:不正确,3.4 是双精度数,将双精度型(double)赋值给浮点型(float)属于向下转型(down-casting,也称为窄化)会造成精度损失,因此需要强制类型转换 float f = (float)3.4; 或者写成 float f = 3.4F; 才可以。