Java中簡單的浮點數類型float和double是不能進行運算的,不光Java,很多語言都是這樣。
我們運行下面程序你將會看到
public class TestMathDecimal { public static void main(String [] args){ System.out.println(0.05+0.01); System.out.println(1.0 - 0.42); System.out.println(4.015 * 100); System.out.println(123.3 / 100); } }
沒錯,結果確實是:
0.060000000000000005
0.5800000000000001
401.49999999999994
1.2329999999999999
我們的第一反應是做四舍五入。Math中的roound是不能夠設置保留幾位小數的。
Math.round(4.015 * 100)的結果為401,而不是我們期望的402。
因此如果我們要進行精確的四舍五入,不能利用簡單類型做任何運算。
java.text.DecimalFormat也不能解決這個問題:
System.out.println(new java.text.DecimalFormat("0.00").format(4.015));輸出的是4.02。
BigDecimal
在商業計算中我們要用java.math.BigDecimal.BigDecimal有四個構造方法,我們不關心BigInteger來構造的那兩個,還有兩個分別是:
BigDecimal(double val)
BigDecimal(String val)
除法運算:
System.out.println(new BigDecimal(153.5).divide(new BigDecimal(100), 2, BigDecimal.ROUND_HALF_UP));
new BigDecimal(100)除數,2精確的位數,BigDecimal.ROUND_HALF_UP:舍入模式
加法運算:
System.out.println(new BigDecimal("2.005").add(new BigDecimal("0.03")));
減法運算:
System.out.println(new BigDecimal("2.00").subtract(new BigDecimal("1.10")));
乘法運算:
System.out.println(new BigDecimal("2.05").multiply(new BigDecimal("10")));
ps:此處可能說的不是很清楚,以后會繼續更新的。