<__NSArrayM: 0x14f09fab0> was mutated while being enumerated.

for ... in遍历时崩溃,因为一边便利数组,又同时修改这个数组里面的内容,导致崩溃,网上的方法如下:

NSMutableArray * arrayTemp = xxx; 

NSArray * array = [NSArray arrayWithArray: arrayTemp];  

for (NSDictionary * dic in array) {        

    if (condition){            

        [arrayTemp removeObject:dic];

    }       

}

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

一个更快接的删除数组里面的内容以及修改数组里面的内容的方法:

[self.selectedArray enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
                InfoModel *tmpModel = (InfoModel *)obj;
                if ([tmpModel.code isEqualToString:currentModel.code]) {
                    *stop = YES;
                    if (*stop == YES) {
                        [self.selectedArray removeObject:tmpModel];
                    }
                    
                }
}];

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

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

你可能感兴趣的:(<__NSArrayM: 0x14f09fab0> was mutated while being enumerated.)