?????blovesaga在一家小超級市場購買一個1.10元棒棒糖,但是他的錢報中都是兩塊一張的鈔票.如果他用一張兩塊的鈔票買這個棒棒糖,那么應該找給他多少零錢呢?
???? 編寫一個程序解決這個問題.
code:
class Change
{
?public static void main(String[] args)
?{
??System.out.println(2.00-1.10);
?}
}
?????? blovesage寫下這段代碼我們期望得到應該找回的零鈔0.90,但是當運行后他發現數據不兌,運行結果為:0.8999999999999999,與預期的0.90不一樣。為什么呢?搞了半天原因在于1.1這個數不能被精確的表示為一個double,因此被表示為最接近它的double值.該程序從2中減去這個值得.遺憾的是,這個結果打印出來并不是接近0.9的double值.這說明: 并不是所有的小數都可以用二進制浮點數精確表示.二進制浮點對于貨幣計算是非常不適合的.
????? 要解決這個問題有兩個辦法:一是使用某種整數類型,例如int或long,并且分單位來計算.如下:
System.out.println((200-110)+"fen");
結果為90分.二是使用執行小數運算的BigDecimal.它還可以通過JDBC與SQL DECIMAL類型進行互操作.這里需要注意的是: 一定要用BigDecimal(String)構造器,而千萬不要用BigDecimal(double).后一個構造器將用它的參數值來創建一個實例.例如new BigDecimal(.1),它將返回一個BigDecimal,也即0.10000000000000000555111512312578270211815834041015625.正確使用我們就可以得到期望的結果0.90:
code:
import java.math.BigDecimal;
class Change
{
?public static void main(String[] args)
?{
??System.out.println(new BigDecimal("2.00").
???????????????????? subtract(new BigDecimal("1.10")));
?}
}
Print:
F:\Java Develop>java Change
0.90
?