iOS - 处理计算精度要求很高的数据,floatValue,doubleValue等计算不精确问题

在iOS开发中,当处理精度要求高的数值计算时,使用float或doubleValue可能会导致结果不精确。例如,0.1乘以999999并不等于预期的9999.99。为解决此问题,可以将数值转换为NSDecimalNumber对象进行计算,支持加减乘除,并能实现四舍五入,确保计算精度。
摘要由CSDN通过智能技术生成

 

1、问题描述:服务器返回的double类型9.94.94的数字时

2、之前处理方式是 :(从内存、cpu计算来说double都是比较合适的,一般情况下都用double)
goodsPrice.floatValue = 9.89999961   ==> 保留2位小数点9.89

3、现在的解决方法是:
goodsPrice.doubleValue = 9.9000000000000003 ==> 保留2位小数点9.90

4、其他的解决方法:
服务器返回的数据全部设置为String类型,就不会出现这样的问题




从内存、cpu计算来说float都是比较合适的,一般情况下都用float

 

 

doublefloat 的区别是double精度高,有效数字16位,float精度7位。但double消耗内存是float的两倍,double的运算速度比float慢得多,C语言中数学函数名称double 和 float不同,不要写错,能用单精度时不要用双精度(以省内存,加快运算速度)。

 

 

 

解决方式之一:

   当设计到金钱的计算.但是利用double类型数据会不稳定.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值