最近一个IOS项目中需要用到很多小数计算,对精度要求很高。我们都知道,对计算机而言Float,Double这类浮点数因为都是以科学计数法方式存储,所以都存在着计算上的误差,所以不能直接对它们进行相关计算。
在每种语言中都有相应的高精度计算方式,如Java中得BigDecimal类,C#中的decimal类型都是用来解决高精度计算问题的,如货币计算。
在对苹果给出的API进行查看后,发现了一个类-----NSDecimalNumber
下面我们就来看看它里面我们需要的方法定义:
- decimalNumberByAdding:
- decimalNumberBySubtracting:
- decimalNumberByMultiplyingBy:
- decimalNumberByDividingBy:
以上4个方法分别代表着我们四则运算中得加减乘除。
这样应该很好理解如何进行我们的高精度计算了,以下为我写的用于理解的例子,addendValue和augendValue为NSString类型,可以将需要运算的数字转化成相应位数的NSString类型后进行高精度计算:
NSDecimalNumber *addendNumber = [NSDecimalNumber decimalNumberWithString:addendValue]; NSDecimalNumber *augendNumber = [NSDecimalNumber decimalNumberWithString:augendValue]; return [addendNumber decimalNumberByAdding:augendNumber];
本文出自 “IT-Fan” 博客,请务必保留此出处http://iteafan.blog.51cto.com/784291/1585053
原文地址:http://iteafan.blog.51cto.com/784291/1585053