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

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