一、隐式转换介绍
把一个取值范围小的数值或者变量,赋值给另一个取值范围大的变量
public class Test {
public static void main(String[] args) {
int a = 10;
double b = a;
System.out.println(b);//10.0
}
}
问题: loat占用4个字节,为什么放在了Long(8个字节)的后面
解释: 虽然fLoat占用4个字节,但是 取值范围要比8个字节的long 更大.(小数的二进制存储形式, 更加节省内存)
运算过程中的隐式转换
取值范围小的数据和取值范围大的数据进行运算,小的会先提升为大的之后,再进行运算
public class Test {
public static void main(String[] args) {
int a = 10;
double b = 12.3;
double c = a + b;//22.3
}
}
byte short char 三种数据在运算的时候,都会提升为int,然后再进行运算
二、强制转换介绍
把一个取值范围大的数值或者变量,赋值给另一个取值范围小的变量不允许直接赋值,需要加入强制转换
格式:目标数据类型 变量名 = (目标数据类型) 被强转的数据
public class Test {
public static void main(String[] args) {
double a = 12.3;
int b = (int) a;
System.out.println(b);//12
}
}
注意:强制转换 有可能会出现精度损失(int转byte时有可能不会)
三、原码、反码和补码
十进制 110
二进制 0b110
八进制 0110(今后编写数值尽量不要以0开头)
十六进制 0x110
四、类型转换面试题
下列代码是否存在错误, 如果有, 请指出说明,并改正。
byte b1 = 3;
byte b2 = 4;
byte b3 = b1 + b2;
错误原因: b1和b2是两个byte类型,在运算的时候,会提升为int类型提升之后,就是两个int在运算了,运算的结果还是int.将int类型的结果,赋值给byte类型的变量,属于大给小,不能直接给。
解决办法
byte b1 = 3;
byte b2 = 4;
byte b3 = (byte)(b1 + b2);
System.out.printin(b3);
升级
byte b = 3 + 4;
这个代码是正确的。
Java存在常最优化机制 : 在编译的时候 (javac) 就会将3和4这两个字面量进行运算.
产生的字节码文件 : byte b = 7;