问题描述
|
将计算结果四舍五入到小数点后两位有问题。
这是一个财务计算,当结果涉及半分钱时,我希望这个数字会被四舍五入,但实际上已经被四舍五入了。
复制问题:
float raw = 16.695;
NSLog(@\"All DP: %f\",raw);
NSLog(@\"2 DP: %.2f\",raw);
返回值:
All DP: 16.695000
2 DP: 16.69
而我希望看到:
All DP: 16.695000
2 DP: 16.70
谁能告诉我这是设计使然,还是(很可能)我缺少某些东西,以及是否有什么办法可以解决。在这种情况下进行汇总至关重要。
提前致谢,
奥利
解决方法
请勿使用3英镑进行财务计算!
有些值不能完全代表浮点数。
16.695
就是其中之一。当您尝试将该值存储为浮点型时,实际上可以得到最接近的可表示值。在float上执行一系列操作时,您可能会失去精度,然后失去准确性。这导致赔钱。
使用实际的货币类型,使用NSDecimalNumber或用ѭ5来进行所有计算,以计算您关心的最小单位(即ѭ6等于10.50美元(整分),或1.050美元(如果要几分钱的话))。
, 据我所知,NSLog()
函数仅采用格式化参数,并且不尝试舍入。
您可能习惯于使用不支持舍入的printf()
样式功能。
我建议使用math.h
中的许多功能之一在输出之前舍入您的值,并且仅依靠NSLog()
进行格式化。
, 看到评论后
使用C标准函数族round()。 roundf()用于float,round()用于double,roundl()用于long double。然后可以将结果转换为您选择的整数类型
, 您可以尝试以下方法:
- (void)testNSlogMethod {
float value = 16.695; //--16.70
value = value *100;
int mulitpler = round(value);
NSLog(@\"%.2f\",mulitpler/100.0f);
}