java小类型可以自动往大类型进行转换,但大类型不能自动往小类型转换,这是为了防止丢失精度,如果非要转换,可以进行强转(将类型如int用一对括号括起来就好了),强转的后果就是丢失精度。不过如果定义一个数据,使用仅数据类型不同的重载方法进行调用,编译器会选择何种重载方法呢?先来看下面这个例子
public class Demo1 {
public static void main(String[] args) {
byte x = 127;
f(x);
}
public static void f(double x){
System.out.println("double:" + x);
}
public static void f(int x) {
System.out.println("int:" + x);
}
public static void f(float x) {
System.out.println("float:" + x);
}
public static void f(short x) {
System.out.println("short:" + x);
}
public static void f(char x) {
System.out.println("char:" + x);
}
public static void f(long x) {
System.out.println("long:" + x);
}
}
所有重载方法参数中并没有byte类型,这时编译器会将char自动向上提升一级,byte提升一级会变成什么类型呢?这就需要知道java八大基本数据类型的层级关系(并非内存占用大小关系):
其中boolean类型不参与其他任何一种数据类型的转换。short和char都会自动提升为int,而byte、short和char之间无法自动转换。根据上图,就很容易得知程序的输出是short:127,但是如果换做是这种情况:
public class Demo1 {
public static void main(String[] args) {
short x = 127;
f(x);
}
public static void f(double x){
System.out.println("double:" + x);
}
public static void f(float x) {
System.out.println("float:" + x);
}
public static void f(char x) {
System.out.println("char:" + x);
}
}
程序会做何种输出呢?其实当编译器发现与short直接上层没有时,它会一直往上寻找直到找到比short层级大的数据类型,在本程序中也就是float,因此程序将输出float:127