我只是尝试使用递增计数器循环遍历一个由(10)个名称组成的列表,方法是取计数器相对于列表长度的模数。然而,代码似乎在这里和那里跳过了一个数字。我试过modf()和modff()以及不同类型的铸件,但没有成功。
下面是一个代码示例:

defaultNameList = [NSArray arrayWithObjects:@"RacerX",@"Speed",@"Sprittle",@"Chim-Chim",@"Pops",@"Dale",@"Junior",@"Chip",@"Fred",@"Barney", nil];

float intpart;
int pickName = (int)(modff(entryCount/10.0,&intpart) * 10.0);
NSLog(@"%ld %f %f %f %d %@",entryCount, entryCount/10.0, modff(entryCount/10.0,&intpart), modff(entryCount/10.0,&intpart) * 10.0 ,pickName, [defaultNameList objectAtIndex:pickName]);

控制台提供:
 0 0.000000 0.000000 0.000000 0 RacerX
 1 0.100000 0.100000 1.000000 1 Speed
 2 0.200000 0.200000 2.000000 2 Sprittle
 3 0.300000 0.300000 3.000000 3 Chim-Chim
 4 0.400000 0.400000 4.000000 4 Pops
 5 0.500000 0.500000 5.000000 5 Dale
 6 0.600000 0.600000 6.000000 6 Junior
 7 0.700000 0.700000 7.000000 6 Junior
 8 0.800000 0.800000 8.000000 8 Fred
 9 0.900000 0.900000 9.000000 8 Fred
 10 1.000000 0.000000 0.000000 0 RacerX

据我所知,它不应该跳过pickName=7或9,但它确实可以。

最佳答案

强制转换为(int)将截断文件。也就是说,如果它不能在实际体系结构上使用的浮点系统中精确地表示,并且比精确值稍小,则它将被舍入为零。要解决此问题,请舍入数字而不是截断:

int pickName = (int)(modff(entryCount / 10.0, &intpart) * 10.0 + 0.5);

(这假设数字不是负数。)
但是,由于这里使用的是整数,而且浮点运算很昂贵,因此应该考虑改用模运算符(它对整数进行运算):
int pickName = entryCount % 10;

10-07 16:37