相关疑难解决方法(0)

如何很好地将浮动数字格式化为字符串而不必要的小数0?

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...)区域设置相关的(见下面的答案).

java string format floating-point double

472
推荐指数
15
解决办法
57万
查看次数

在Java中从BigDecimal中删除尾随零

我需要删除尾随零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中的自定义转换器中使用它,这对最终用户来说可能很难看.那么,这样做的正确方法是什么?

java bigdecimal

52
推荐指数
4
解决办法
4万
查看次数

仅当小数重复时才设置BigDecimal精度

我知道我可以使用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.

a1a2从用户输入实例化.

有什么方法可以解决这个问题吗?

java precision bigdecimal

3
推荐指数
1
解决办法
658
查看次数

标签 统计

java ×3

bigdecimal ×2

double ×1

floating-point ×1

format ×1

precision ×1

string ×1