时间:2021-05-02
做了好一段时间的金融产品,对数字是要非常敏感,差个零点零几都不行,精确度是要非常重视的,将后台传给我的floatValue转成NSString,一直没发现问题,最近项目有关个人账户的资产显示,发现总是和web和android有点误差,百思不得其解,在Stack Overflow上面问了一下,发现了NSDecimalNumber这个API,这个类为OC程序提供定点算法功能,它被设计不会损失精度并且可预先设置凑整规则的10进制计算,它比浮点数更好去表达货币,作为代价,它的计算相对复杂,相对耗时。
举个栗子:
? 1 2 3 4 5 6 float a = 0.01; int b = 99999999; double c = 0.0; c = a * b; NSLog(@"%f",c); NSLog(@"%.2f",c); 2017-08-02 15:41:25.620 DecimalNumber[3014:155231] 1000000.000000
2017-08-02 15:41:25.620 DecimalNumber[3014:155231] 1000000.00
明显已经已经失真了。
那么我们换个类型,把精度调高,会不会好点呢?
? 1 2 3 c = a*(double)b; NSLog(@"%f",c); NSLog(@"%.2f",c);然并卵,
2017-08-02 16:16:32.293 DecimalNumber[3144:167125] 999999.967648
2017-08-02 16:16:32.294 DecimalNumber[3144:167125] 999999.97
这都是什么鬼,数学白学了。
最后想到了一个方法,我把它转成了字符串,然后再转成double类型,没想到精度就达到要求了
? 1 2 3 4 5 6 7 NSString *aString = [NSString stringWithFormat:@"%.2f", a]; NSString *bSting = [NSString stringWithFormat:@"%.2f", (double)b]; c = [aString doubleValue] * [bString doubleValue]; NSLog(@"%.2f",c);2017-08-02 16:27:32.590 DecimalNumber[3252:172900] 999999.99
不过看起来有点别扭,转过来转过去的就不说了,一看感觉感觉不专业。下面通过NSDecimalNumber提供计算方式,这是官方建议的货币计算API,精确度比较高,对乘除计算都有单独的接口提供。
? 1 2 3 4 5 6 7 NSDecimalNumber *decimalNumber1 = [NSDecimalNumber decimalNumberWithString:aString]; NSDecimalNumber *decimalNumber2 = [NSDecimalNumber decimalNumberWithString:bString]; NSDecimalNumber *result = [decimalNumber1 decimalNumberByMultiplyingBy:decimalNumber2]; NSLog(@"%@",result);2017-08-02 16:35:32.779 DecimalNumber[3369:177485] 999999.99
这样看起来就舒服多了,精确度也得到了满足
在对于货币的计算显示,要时刻注意精度的问题。优先选用此API,下面是官方的说明NSDecimalNumber
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.jianshu.com/p/c6360cb13d0e?utm_source=tuicool&utm_medium=referral
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在进行浮点数计算时它们无法精确表达出所有的十进制小数位。a=4.1b=5.329print(a+b)9.428999999999998这些误差实际上是底层CPU
问题: 数据库里的floatmomey类型,都会精确到多位小数。但有时候我们不需要那么精确,例如,只精确到两位有效数字。 解决: 1.使用Round(
JS无法进行精确计算的bug在做CRM,二代审核需求审核详情页面时。需要按比例(后端传类似0.8的小数)把用户输入的数字显示在不同的地方。在做dubheInve
在SQLServer中实际上只有两种小数数值类型,分别是float(近似数值)和decimal(精确数值),这两种类型能表示所有的小数数值类型。float(近似
汽车油耗计算器.版本2.程序集窗口程序集_启动窗口.子程序_计算按钮_被单击.局部变量公里,双精度小数型.局部变量油量,双精度小数型.局部变量油价,双精度小数型