Java中的数据类型转换
- 转换规则
- 八种基本数据类型当中除boolean类型之外剩下的七种类型之间都可以互相转换
- 小容量向大容量转换,称为自动类型转换;容量从小到大排序:byte < short < int < long <float < double < char
注意:任何浮点类型不管占用多少个字节都比整数型容量大
char和short可表示的种类数量相同,但是char可以取更大的正整数- 大容量转换成小容量,称为强制类型转换,需要加强制类型转换符,程序才可能编译通过,但是在运行阶段可能会损失精度,所以谨慎使用。
- 当整数字面值没有超出byte,short, char的取值范围,可以直接赋值给byte,short, char类型的变量
- byte,short, char混合运算时,各自先转换成int类型再做运算
- 多种数据类型混合运算,先转换成容量最大的那种类型再做运算
注意:
byte b = 3; 可以编译通过,3没有超出byte类型取值范围
int i = 10;
byte b = i / 3; 编译报错,编译器只检查语法,不会"运算" i / 3
举例说明:
public class test01
{
public static void main (String[] args) {
// 出现错误,1000超出了byte范围
// byte a = 1000;
// 正确,因为20没有超出byte范围
// 所以赋值
byte a = 20;
// 变量不能重名
// short a = 1000;
// 正确,因为数值1000没有超出short类型的范围
// 所以赋值正确
short b = 1000;
// 正确,因为默认就是int类型,并且没有超出int范围
int c = 1000;
// 正确,可以自动转换
long d = c;
// 错误,出现精度丢失问题,大类型-->>小类型会出现问题
// int e = d;
// 将long强制转换成int类型
// 因为值1000,没有超出int范围,所以转换是正确的
int e = (int)d
// 因为Java中的运算会转成最大类型
// 而10和3默认为int,所以运算后的最大类型也是int
// 所以是正确的
int f = 10/3; //3
// 声明10为long类型
long g = 10;
// 出现错误,多个数值在运算过程中,会转换成容量最大的类型
//以下示例最大的类型为double,而h为int,所以就会出现大类型(long)到小类型(int)的转换,将会出现精度丢失问题
// int h = g/3;
// 可以强制类型转换,因为运算结果没有超出int范围
// int h = (int) g/3;
// 可以采用long类型来接收运算结果
// long h = g/3;
// 出现精度损失问题,以下问题主要是优先级的问题
// 将g转换成int,然后又将int类型的g转换成byte,最后byte类型的g和3运算,那么它的运算结果类型就是int,所以int赋值给byte就出现了精度损失问题
// byte h = (byte)(int)g/3;
// 正确
// byte h = (byte)(int)(g/3);
// 不能转换,还有因为优先级的问题
// byte h = (byte)g/3;
// 可以转换,因为运算结果没有超出byte范围
// byte h = (byte)(g/3);
// 可以转换,因为运算结果没有超出short范围
short h = (short)(g/3);
short i = 10;
byte j = 5;
// 错误,short和byte运算,首先会转换成int再运算
// 所以运算结果是int,int赋值给short就会出现精度丢失问题
// short k = i + j;
// 可以将运算结果强制转换成short
// short k = (short)(i + j);
// 因为运算结果为int,所以可以采用int类型接收
int k = i + j;
char l = 'a';
System.out.println(l);
// 输出结果为97,也就是a的ascii值
System.out.println((byte)l);
int m = l + 100;
// 输出结果为197,取得a的ascii码值,然后与100进行相加运算
System.out.println(m);
}
}