以下为测试代码:
int x = 30; // 定义整数 x = 30
double d = x / 40;
System.out.println("d值====" + d);// 该语句就是打印出 通过计算的 d值 = 0.0
System.out.println("x / 40值====" + x / 40);// 该语句就是打印出x除以40的结果 = 0
System.out.println("(double) x / 40===" + (double) x / 40);// 该语句就是打印出(double)x除以40
// = 0.75
System.out.println("(double) (x / 40)===" + (double) (x / 40));// = 0.0
float y = 4.000001f;
System.out.println(10/y);//= 2.4999995
float z = 4.00000f;
System.out.println(10/z); //= 2.5
System.out.println(10.1110/0.4); //= 25.2775
// 结论为 两数像除结果显示取 精度最大,
结果显示:
x / 40值====0
(double) x / 40===0.75
(double) (x / 40)===0.0
2.4999995
2.5
25.2775
float z = 4.00000f;
System.out.println(10/z); //= 2.5 为什么结果显示不把后面的0不全