64位双精度可以精确地表示整数+/- 2 53
鉴于这一事实,我选择将double类型用作所有类型的单一类型,因为我的最大整数是无符号32位.
但现在我必须打印这些伪整数,但问题是它们也与实际双打混合在一起.
那么如何在Java中很好地打印这些双打?
我试过了String.format("%f", value),这很接近,除了我得到很多小值的尾随零.
这是一个示例输出 %f
232.00000000 0.18000000000 1237875192.0 4.5800000000 0.00000000 1.23450000
我想要的是:
232 0.18 1237875192 4.58 0 1.2345
当然,我可以编写一个函数来修剪这些零,但由于字符串操作,这会导致很多性能损失.我可以用其他格式代码做得更好吗?
编辑
Tom E.和Jeremy S.的答案是不可接受的,因为它们都可以任意舍入到小数点后两位.请在回答之前先了解问题.
编辑2
请注意,String.format(format, args...)是区域设置相关的(见下面的答案).
我需要删除尾随零BigDecimal沿RoundingMode.HALF_UP.例如,
Value Output
15.3456 <=> 15.35
15.999 <=> 16 //No trailing zeros.
15.99 <=> 15.99
15.0051 <=> 15.01
15.0001 <=> 15 //No trailing zeros.
15.000000<=> 15 //No trailing zeros.
15.00 <=> 15 //No trailing zeros.
Run Code Online (Sandbox Code Playgroud)
stripTrailingZeros() 有效,但它会在类似的情况下返回科学记数,
new BigDecimal("600.0").setScale(2, RoundingMode.HALF_UP).stripTrailingZeros();
Run Code Online (Sandbox Code Playgroud)
在这种情况下,它返回6E+2.我需要在JSF中的自定义转换器中使用它,这对最终用户来说可能很难看.那么,这样做的正确方法是什么?
我知道我可以使用BigDecimal.divide()方法来设置固定的精度:
BigDecimal a1 = new BigDecimal(1);
BigDecimal a2 = new BigDecimal(3);
BigDecimal division = a1.divide(a2,5,1); //equals 0.33333
Run Code Online (Sandbox Code Playgroud)
但如果除法结果是准确的:
BigDecimal a1 = new BigDecimal(1);
BigDecimal a2 = new BigDecimal(4);
BigDecimal division = a1.divide(a2,5,1); //equals 0.25000
Run Code Online (Sandbox Code Playgroud)
如何设置除法结果,如果除法以精确结果结束,它将只输出0.25而不是0.25000?
我还试图通过这样做来指定精度:
BigDecimal division = a1.divide(a2);
Run Code Online (Sandbox Code Playgroud)
它在执行0.25时成功地给出了结果1/4,但是当它像分区一样1/3或者2/3它导致运行时ArithmeticException.
a1并a2从用户输入实例化.
有什么方法可以解决这个问题吗?