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));
ringa_lee
首先,指出一個問題:建構 BigDecimal 的时候,尽量不要使用浮点数(double,float),因為浮點數在電腦中的儲存存在精度缺失問題。例如你的寫的程式碼:
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 的捨入模式:
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 的用法」
RoundingMode
第三,關於 DecimalFormat 括號裡的字串代表的意思,請自行搜尋 「DecimalFormat 的用法」
雷雷
首先,指出一個問題:建構
BigDecimal
的时候,尽量不要使用浮点数(double
,float
),因為浮點數在電腦中的儲存存在精度缺失問題。例如你的寫的程式碼:運行結果:
可以看到,浮點數 1.505 在電腦中沒辦法儲存的 —— 具體原因如果不知道,請自行搜尋 「浮點數精度缺失問題」
第二,如果需要輸出 1.51,即常說的 “四捨五入”,那麼需要指定
DecimalFormat
的捨入模式:運行結果:
如果不了解
RoundingMode
的用法,請自行搜尋 「RoundingMode 的用法」第三,關於
DecimalFormat
括號裡的字串代表的意思,請自行搜尋 「DecimalFormat 的用法」雷雷