阅读本文章前,请先了解java基本数据类型,若想复习或了解,请阅读本博主《3.java的数据类型》
自动类型转换
数字表示范围小的数据类型可以自动转换成范围大的数据类型。
byte
-> short
-> char
-> int
-> long
-> float
-> double(
从小类型到大类型)
注:byte、short、char这三者之间不会相互转换,他们三者在计算时首先都会转换为 int 类型;boolean类型不能与其他任何基本数据类型进行转换;超出范围的强制转型会得到错误的结果。
例如,将一个int类型的值赋给一个long类型的变量,编译器会自动将int类型的值转换为long类型的值。
例子:
public class MyClass {
public static void main(String[] args) {
int myInt = 10;
double myDouble = myInt; // 自动转换: int 到 double
System.out.println(myInt); // 输出 10
System.out.println(myDouble); // 输出 10.0
}
}
强制类型转换
将较大的类型转换为较小的类型时使用,需要强制转换符实现强制转换。
例子:
public class MyClass {
public static void main(String[] args) {
double myDouble = 10.00;
int myInt = (int) myDouble; // 手动转换:double 到 int
System.out.println(myDouble); // 输出 10.00
System.out.println(myInt); // 输出 10
}
}
注:类型转换时可能会导致溢出或精度的丢失,另外浮点数到整数的转换是通过舍弃小数得到的,而不是四舍五入。
总结
接下来引入一些经典的面试题
1.short s1 = 1; s1 = s1 + 1;
错误。s1是short类型,1是int型,s1会自动转换为int型的1,与1相加后,得到int型的2,要向左侧的short类型的s1看齐,即需要通过强制类型转换。正确写法:s1 = (short) (s1 + 1);
2.short s1 = 1; s1 += 1;
正确。 由于 += 是java语言规定的运算符,java编译器会对它进行特殊处理。因此执行s1+=1;其实执行的是s1 = (short) (s1 + 1); 其中会有一个强制转换的过程。
3.float n = 1.8
错误。对于小数,默认情况,3.4此时为double类型,所以float f=3.4;这个写法是错误的,1.8是double类型,需要强制转换为float类型。
正确写法:float n = float(1.8);float n = 1.8f;