當我開始編寫第一個應用程序的代碼時,我使用NSNumber來獲取貨幣值,而無需三思而后行。然后我認為也許c類型足以應付我的價值觀。但是,由于其出色的舍入功能,在iPhone SDK論壇中建議我使用NSDecimalNumber。我不是氣質的數學家,我認為尾數/指數范式可能會過大。仍然,googlin,我意識到,關于可可中的金錢/貨幣的大多數討論都提到了NSDecimalNumber。請注意,我正在使用的應用程序將被國際化,因此以美分計算金額的選擇實際上并不可行,因為貨幣結構在很大程度上取決于所使用的語言環境。我90%的人肯定我需要使用NSDecimalNumber,但是由于我在網絡上沒有找到明確的答案(例如:“如果您要花錢,請使用NSDecimalNumber!”),我想在這里問一下。也許答案對大多數人來說是顯而易見的,但是我想在開始大規模重構應用程序之前先確定一下。說服我 :)
3 回答

慕田峪9158850
TA貢獻1794條經驗 獲得超7個贊
(改編自我對其他答案的評論。)
是的你應該。僅當您不需要代表半分錢時,整數便士才能起作用。如果發生這種情況,您可以將其更改為半美分,但是如果您需要代表四分之一美分或八分之一美分呢?
唯一合適的解決方案是NSDecimalNumber(或類似的東西),它將問題推遲到10 ^ -128¢(即
0.0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000001¢)。
(另一種方法是任意精度算術,但是需要一個單獨的庫,例如GNU MP Bignum庫。GMP在LGPL之下。我從未使用過該庫,也不知道它是如何工作的,所以我無法說出它對您的效果如何。)
[編輯:顯然,至少有一個人布拉德·拉爾森(Brad Larson)認為我在這個答案的某個地方談論二進制浮點數。我不是。]
添加回答
舉報
0/150
提交
取消