zoukankan      html  css  js  c++  java
  • 解决Collection <__NSArrayM: 0x7f8168f7a750> was mutated while being enumerated.'

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

    NSMutableArray * arrayTemp = xxx;
     
    NSArray * array = [NSArray arrayWithArray: arrayTemp];
     
    for (NSDictionary * dic in array) {
       if (condition){
          [arrayTemp removeObject:dic];
       }
    }
    
    

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

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

    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%左右,这个的原理是这样的:

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

    这种方法非常简单哟

    追寻最真
  • 相关阅读:
    云? 云! 晕! 云计算适合创业公司么?
    批量转移Windows Server的DNS设置
    Signs that you are a bad programmer
    IsNull Function in PeopleSoft MetaSQL
    JS绘制曲线图
    Why does my shared clipboard not work?
    C#入门详解(2)
    C#入门详解(1)
    分享范玮琪最初的梦想
    像战士一样生活
  • 原文地址:https://www.cnblogs.com/zhao-jie-li/p/5416483.html
Copyright © 2011-2022 走看看