首页 > 代码库 > 当程序出现这个提示的时候,是因为你一边遍历数组,又同时修改这个数组里面的内容,导致崩溃

当程序出现这个提示的时候,是因为你一边遍历数组,又同时修改这个数组里面的内容,导致崩溃

2014-12-17 16:22:15.838 贵金属走势[4638:150754] *** Terminating app due to uncaught exception ‘NSGenericException‘, reason: ‘*** Collection <__NSCFArray: 0x799dba00> was mutated while being enumerated.‘

当程序出现这个提示的时候,是因为你一边遍历数组,又同时修改这个数组里面的内容,导致崩溃,网上的方法如下:

1
2
3
4
5
6
7
8
9
NSMutableArray * arrayTemp = xxx;
 
NSArray * array = [NSArray arrayWithArray: arrayTemp];
 
for (NSDictionary * dic in array) {
   if (condition){
      [arrayTemp removeObject:dic];
   }
}

这种方法就是在定义一个一模一样的数组,遍历数组A然后操作数组B

今天终于找到了一个更快接的删除数组里面的内容以及修改数组里面的内容的方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
NSMutableArray *tempArray = [[NSMutableArray alloc]initWithObjects:@"12",@"23",@"34",@"45",@"56"nil];
 
[tempArray enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
 
if ([obj isEqualToString:@"34"]) {
 
*stop = YES;
 
if (*stop == YES) {
 
[tempArray replaceObjectAtIndex:idx withObject:@"3333333"];
 
}
 
}
 
if (*stop) {
 
NSLog(@"array is %@",tempArray);
 
}
 
}];

利用block来操作,根据查阅资料,发现block遍历比for遍历快20%左右,这个的原理是这样的:

找到符合的条件之后,暂停遍历,然后修改数组的内容

这种方法非常简单哟

当程序出现这个提示的时候,是因为你一边遍历数组,又同时修改这个数组里面的内容,导致崩溃