Java程序中要求参与的计算的数据,必须要保证数据的一致性,如果数据类型不一致将会发生类型的转换
例如:
public class Demo01DataType{
public static void main(String[] args){
System.out.println(1024); // 这是个整数, 默认为int类型
System.out.println(3.14); // 这是个浮点数,默认为double类型
// 左边是long 类型,右边是默认的int 类型,左右不一样
long num1 = 100;
System.out.println(num1);
}
}
一、自动类型转换
一个int类型变量和一个byte类型的变量进行加法运算,结果会是什么数据类型?
int i = 1;
byte b = 2;
运算结果,变量的类型将是int类型,这就是出现了数据类型的自动类型转换现象。
1、定义
- 自动转换:将
取值范围小的类型转换为取值范围大的类型。
public static void main(String[] args){
int i = 1;
byte b = 2;
// byte x = b + i; // 报错
// int 类型和 byte 类型运算,结果是int 类型
int j = i + b;
System.out.println(j);
}
2、特点
代码不需要进行特殊处理,自动完成。
数据范围从小到大, 数据范围与其对应的字节数不成正相关,即字节数越大数据范围不一定越大
// 左边是long类型,右边是默认的int 类型 // 改行代码表示将int --> long, 符合了数据范围从小到大的要求 // 这一行代码发生了自动类型转换 long num1 = 100; // 左边是double类型,右边是float类型,左右不一样 // float --> double ,符合从小到大的规则 double num2 = 2.5F; // 左边是float类型,右边是long类型 // long --> float,范围float类型更大,符合从小到大的规则 // 发生自动类型转换 float num3 = 30L;
二、强制类型转换
将1.5赋值给int类型变量会发生什么?产生编译失败,无法赋值
double类型内存8个字节,int类型内存4个字节。1.5是double类型,取值范围大于int。可以理解为double是8升水,int是4升水,不能把大水壶中的水直接放到小水壶中去。
想要赋值成功,只有通过强制类型转换,将double类型强制转换为int类型才能赋值。
1、定义
将取值范围大的类型强制转换成取值范围小的类型.
比较而言,自动转换是Java自动执行的,而强制转换需要我们手动执行。
格式:
数据类型 变量名 = (数据类型) 被转数据值
2、特点
- 代码需要进行特殊的格式处理,不能自动完成
- 格式:范围小的类型 范围小的变量名 = (范围小的类型) 原本范围大的数据
public class Demo02DataType{
public static void main(String[] args){
// 左边是 int 类型, 右边默认是int 类型,不会发生类型转换
int num1 = 100;
System.out.println(num1);
// 左边是 int 类型, 右边是 long类型
// long --> int, 数据范围不是从小到大
// 不能发生自动类型转换
//int num2 = 100L;
//System.out.println(num2);
// 进行强制类型转换
int num3 = (int) 100L;
System.out.println(num3);
}
}
3、注意事项
(1)、强制类型转换一般不推荐使用,因为有可能发生精度损失、数据溢出
- 数据溢出
// 情况一
// 右边虽然是long类型,但是经过强制类型转换后变成int类型,但是100这个数值并没有超过int类型的范围
int num1 = (int) 100L;
// 情况二
//在这种情况下,右边是60亿,而默认的整数类型是int,其最大范围是约21个亿,这里就本身会产生一个错误,所以需要在其后面加上一个L,此时左边 int, 右边是 long,需要强制类型转换
// int num2 = 6000000000;
// 此时long强制转换为int类型,但是60亿已经超过了int类型范围, 发生数据溢出
int num2 = (int) 6000000000L;
System.out.println(num2); //输出为 1705032704
- 精度损失
// double --> int, 强制类型转换
int num3 = (int) 3.99;
System.out.println(num3); // 输出为3,不是四舍五入,所有小数位都会被舍弃掉
(2)、byte/short/char这三种类型都可以发生数学运算,例如加法”+”
char c1 = 'A';
System.out.println(c1 + 1); // 66
(3)、byte/short/char这三种类型在运算的时候,都会被首先提升为int类型,然后再计算
byte num3 = 40;
byte num4 = 50;
//byte + byte --> int + int --> int
// byte res = num3 + num4; // 错误
int res = num3 + num4;
System.out.println(res);
short num6 = 60;
// byte + short --> int + int --> int
int res1 = num4 + num6;
// 强制类型转换
short res2 = (short)(num4 + num6);
System.out.println(res1);
System.out.println(res2);