在 Java 中,我们可以将 int 隐式转换为 float,这可能会导致精度损失,如下面的示例代码所示。
public class Test {
public static void main(String [] args) {
int intVal = 2147483647;
System.out.println("integer value is " + intVal);
double doubleVal = intVal;
System.out.println("double value is " + doubleVal);
float floatVal = intVal;
System.out.println("float value is " + floatVal);
}
}
输出是
integer value is 2147483647
double value is 2.147483647E9
float value is 2.14748365E9
当精度损失时,允许将 int 隐式转换为 float 的原因是什么?