GitHub Demo: https://github.com/BaHui/BigNumber
簡介
<ethers>開源框架中摘錄的BigNumber類, 用于
大整數(shù)
的運算和比較 , 稍作整理, 去除了業(yè)務(wù)上面的代碼模塊. 改為較為通用的BigNumber
類, 繼承自NSObject
.
場景
在特定場景下, 基本數(shù)據(jù)類型的運算可能已經(jīng)滿足不了需求了, 為了避免數(shù)據(jù)的隱式轉(zhuǎn)換, 那么就需要
大數(shù)
的運算了. 了解下基本數(shù)據(jù)類型的取值范圍:
int:2147483648~2147483647
unsigned int:0~4294967295
unsigned long:0~4294967295
long:2147483648~2147483647
long long:-9223372036854775808~9223372036854775807
unsigned long long:1844674407370955161
__int64:-9223372036854775808~9223372036854775807
unsigned __int64:18446744073709551615
接口聲明
@interface BigNumber : NSObject
// ** Constant Values **
+ (BigNumber *)constantNegativeOne;
+ (BigNumber *)constantZero;
+ (BigNumber *)constantOne;
+ (BigNumber *)constantTwo;
// ** Init Methods **
+ (instancetype)bigNumberWithDecimalString:(NSString *)decimalString;
+ (instancetype)bigNumberWithNumber:(NSNumber *)number;
+ (instancetype)bigNumberWithInteger:(NSInteger)integer;
// ** Calculate Methods **
- (BigNumber *)add:(BigNumber *)other;
- (BigNumber *)sub:(BigNumber *)other;
- (BigNumber *)mul:(BigNumber *)other;
- (BigNumber *)div:(BigNumber *)other;
- (BigNumber *)mod:(BigNumber *)other;
// ** Compare Methods **
- (BOOL)equalTo:(BigNumber *)other;
- (BOOL)lessThan:(BigNumber *)other;
- (BOOL)lessThanEqualTo:(BigNumber *)other;
- (BOOL)greaterThan:(BigNumber *)other;
- (BOOL)greaterThanEqualTo:(BigNumber *)other;
@end
使用姿勢
BigNumber *firstBigNumber = [BigNumber bigNumberWithDecimalString:@"321641232112"];
BigNumber *secondBigNumber = [BigNumber bigNumberWithNumber:@(999424241)];
// 加
BigNumber *addResult = [firstBigNumber add:secondBigNumber];
NSLog(@"addResult: %@", addResult.decimalString);// 輸出: 322640656353
// 減
BigNumber *subResult = [firstBigNumber sub:secondBigNumber];
NSLog(@"subResult: %@", subResult.decimalString);// 輸出: 320641807871
// 乘
BigNumber *mulResult = [firstBigNumber mul:secondBigNumber];
NSLog(@"mulResult: %@", mulResult.decimalString);// 輸出: 321456044277840426992
// 除
BigNumber *divResult = [firstBigNumber div:secondBigNumber];
NSLog(@"divResult = %@", divResult.decimalString);// 輸出: 321
// 余
BigNumber *modResult = [firstBigNumber mod:secondBigNumber];
NSLog(@"modResult = %@", modResult.decimalString);// 輸出: 826050751
// 比較
BOOL isEqual = [firstBigNumber isEqualTo:secondBigNumber];
NSLog(@"是否相等: %@", isEqual ? @"相等" : @"不相等");// 輸出: 不相等
BOOL isFirstLessThanEqualToSecondNumber = [firstBigNumber lessThanEqualTo:secondBigNumber];
NSLog(@"大小比較: %@", isFirstLessThanEqualToSecondNumber ? @"不大于" : @"大于");// 輸出: 大于