我将一些floatvalues导出到Textfile(JSONFormat)中,然后再将它导入我的项目中。奇怪的是,NSNumberformatter接受字符串并自行添加一些随机(?)小数位....
这是我从NSLog获得的:
[9697:207] f1 150.837296 - f2 150,8373
[9697:207] f1 160.746902 - f2 160,7469
[9697:207] f1 150.242599 - f2 150,2426
[9697:207] f1 160.068893 - f2 160,0689
[9697:207] f1 149.451096 - f2 149,4511
[9697:207] f1 159.154205 - f2 159,1542
如您所见,右边的值是我的输入字符串(f2),左边的值是我的浮点数(f1)。
继承我的代码:
NSNumberFormatter *formatter = [[NSNumberFormatter alloc] init];
[formatter setNumberStyle:NSNumberFormatterDecimalStyle];
[formatter setDecimalSeparator:@","];
float f1 = (float)[[formatter numberFromString:[mutableArray objectAtIndex:i]] floatValue];
为什么会发生这种情况?
答案 0 :(得分:4)
此效果的原因是float
类型,因为float是不精确的类型。
见下面的例子:
NSNumberFormatter *formatter = [[[NSNumberFormatter alloc] init] autorelease];
[formatter setNumberStyle:NSNumberFormatterDecimalStyle];
[formatter setDecimalSeparator:@","];
float f1 = [[formatter numberFromString:@"150,8373"] floatValue];
NSLog(@"%.8f", f1); //150.83729553
NSLog(@"%.4f", f1); //150.8373 - formatting hides a tail
double f1 = [[formatter numberFromString:@"150,8373"] double];
NSLog(@"%.8f", f1); //150.83730000
因此,使用double
来获得正确的精确度。