double d = 4.321562;
有没有一种简单的方法可以从d中自行提取0.321562?我试着看数学课,但没有运气。如果这可以在不转换为字符串或转换为其他任何内容的情况下完成,那就更好了。
答案 0 :(得分:29)
嗯,你可以使用:
double x = d - Math.floor(d);
请注意,由于二进制浮点的工作方式,它不会为您提供完全 0.321562,因为原始值不是完全 4.321562。如果您对确切的数字感兴趣,请改用BigDecimal
。
答案 1 :(得分:27)
在不使用Math的情况下获取分数的另一种方法是强制转换为。
double x = d - (long) d;
当您打印double
时,toString将执行少量舍入,因此您不会看到任何舍入错误。但是,当您删除整数部分时,舍入不再足够,并且舍入错误变得明显。
解决这个问题的方法是自己进行舍入或使用允许您控制舍入的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
答案 2 :(得分:9)
使用modulo:
double d = 3.123 % 1;
assertEquals(0.123, d,0.000001);