如何获得小数点后的数字?(java)

2022-09-01 19:49:36
 double d = 4.321562;

有没有一种简单的方法可以从d中提取0.321562?我试着在数学课上看,但没有运气。如果这可以在不转换为字符串或转换为其他任何内容的情况下完成,那就更好了。


答案 1

好吧,您可以使用:

double x = d - Math.floor(d);

请注意,由于二进制浮点数的工作方式,这不会给出正好0.321562,因为原始值不完全是4.321562。如果您真的对确切的数字感兴趣,则应改用。BigDecimal


答案 2

在不使用数学的情况下获得分数的另一种方法是转换为长。

double x = d - (long) d;

打印时,toString 将执行少量舍入,因此您不会看到任何舍入错误。但是,当您删除整数部分时,舍入不再足够,舍入误差变得明显。double

解决这个问题的方法是自己进行舍入或使用BigDecimal,它允许您控制舍入。

double d = 4.321562;
System.out.println("Double value from toString " + d);
System.out.println("Exact representation " + new BigDecimal(d));
double x = d - (long) d;
System.out.println("Fraction from toString " + x);
System.out.println("Exact value of fraction " + new BigDecimal(x));
System.out.printf("Rounded to 6 places %.6f%n", x);
double x2 = Math.round(x * 1e9) / 1e9;
System.out.println("After rounding to 9 places toString " + x2);
System.out.println("After rounding to 9 places, exact value " + new BigDecimal(x2));

指纹

Double value from toString 4.321562
Exact representation 4.321562000000000125510268844664096832275390625
Fraction from toString 0.3215620000000001
Exact value of fraction 0.321562000000000125510268844664096832275390625
Rounded to 6 places 0.321562
After rounding to 9 places toString 0.321562
After rounding to 9 places, exact value 0.32156200000000001448796638214844278991222381591796875

注意:精度有限,如果不使用适当的舍入,您可以看到表示问题蔓延。这可能发生在您与esp数字一起使用的任何计算中,这些数字不是2的幂的精确和。doubledouble