最近一个IOS项目中需要用到很多小数计算,对精度要求很高。我们都知道,对计算机而言Float,Double这类浮点数因为都是以科学计数法方式存储,所以都存在着计算上的误差,所以不能直接对它们进行相关计算。

在每种语言中都有相应的高精度计算方式,如Java中得BigDecimal类,C#中的decimal类型都是用来解决高精度计算问题的,如货币计算。

在对苹果给出的API进行查看后,发现了一个类-----NSDecimalNumber


下面我们就来看看它里面我们需要的方法定义:


- decimalNumberByAdding:

- decimalNumberBySubtracting:

- decimalNumberByMultiplyingBy:

- decimalNumberByDividingBy:


以上4个方法分别代表着我们四则运算中得加减乘除。


这样应该很好理解如何进行我们的高精度计算了,以下为我写的用于理解的例子,addendValue和augendValue为NSString类型,可以将需要运算的数字转化成相应位数的NSString类型后进行高精度计算:

NSDecimalNumber*addendNumber=[NSDecimalNumberdecimalNumberWithString:addendValue];NSDecimalNumber*augendNumber=[NSDecimalNumberdecimalNumberWithString:augendValue];NSDecimalNumber*sumNumber=[addendNumberdecimalNumberByAdding:augendNumber];