1.为什么不是1.51?输出的是1.50
2.decimalformat括号里的字符串代表了什么意思?有模板吗?如果是别的格式应该怎么写
3.为什么要用#号而不是0.00?如果是#好的话,当a是0.505的时候有bug
double a =1.505;
BigDecimal bd = new BigDecimal(a);
System.out.println(new DecimalFormat("#.00").format(bd));
高洛峰2017-04-18 10:53:52
首先,指出一個問題:建構 BigDecimal
的时候,尽量不要使用浮点数(double
,float
),因為浮點數在電腦中的儲存存在精度缺失問題。例如你的寫的程式碼:
public static void main(String[] args) throws Exception {
double a = 1.505;
BigDecimal bd = new BigDecimal(a);
System.out.println("bd: " + bd.toString());
}
運行結果:
可以看到,浮點數 1.505 在電腦中沒辦法儲存的 —— 具體原因如果不知道,請自行搜尋 「浮點數精度缺失問題」
第二,如果需要輸出 1.51,即常說的 “四捨五入”,那麼需要指定 DecimalFormat
的捨入模式:
public static void main(String[] args) throws Exception {
BigDecimal bd = new BigDecimal("1.505");
System.out.println("bd: " + bd.toString());
DecimalFormat df = new DecimalFormat("#.00");
df.setRoundingMode(RoundingMode.HALF_UP);
System.out.println("format: " + df.format(bd));
}
運行結果:
如果不了解 RoundingMode
的用法,請自行搜尋 「RoundingMode 的用法」
第三,關於 DecimalFormat
括號裡的字串代表的意思,請自行搜尋 「DecimalFormat 的用法」