有许多类似标题的问题,但没有一个问题对我有帮助。
但是我可以将此'NSGenericException', reason: Collection <__NSArrayM: 0x7fabb400> was mutated while being enumerated的解决方案联系起来 问我的问题。 因为这种终止正在发生 当我添加时,删除带有数组的字符串对象。
错误:
由于未捕获的异常'NSGenericException'而终止应用, 原因:'*** Collection&lt; __ NSArrayM:0x7fa1f2711910&gt;在被列举时被突变。'
第一次抛出调用堆栈:
(
0 CoreFoundation 0x00000001087b8c65 __exceptionPreprocess + 165
1 libobjc.A.dylib 0x0000000108422bb7 objc_exception_throw + 45
2 CoreFoundation 0x00000001087b85c4 __NSFastEnumerationMutationHandler + 132
3 0x0000000107e24cf5 -[ProfessionalRegSecond tableView:didDeselectRowAtIndexPath:] + 773
4 UIKit 0x0000000109759d71 -[UITableView _deselectRowAtIndexPath:animated:notifyDelegate:] + 347
5 UIKit 0x000000010974deea -[UITableView _userSelectRowAtPendingSelectionIndexPath:] + 187
6 UIKit 0x000000010968062c _applyBlockToCFArrayCopiedToStack + 314
7 UIKit 0x00000001096804a6 _afterCACommitHandler + 533
8 CoreFoundation 0x00000001086ebca7 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 23
9 CoreFoundation 0x00000001086ebc00 __CFRunLoopDoObservers + 368
10 CoreFoundation 0x00000001086e1a33 __CFRunLoopRun + 1123
11 CoreFoundation 0x00000001086e1366 CFRunLoopRunSpecific + 470
12 GraphicsServices 0x000000010d6c8a3e GSEventRunModal + 161
13 UIKit 0x000000010965c900 UIApplicationMain + 1282
14 0x0000000107de14cf main + 111
15 libdyld.dylib 0x000000010b585145 start + 1
)
libc ++ abi.dylib:以NSException类型的未捕获异常终止
我正在尝试做什么:
我需要这样的方式,当我选择单元格时,我想将该对象添加到数组&amp;当我取消选择行时,我想从数组中删除该行,因此结果数组将只是选中的条目。怎么做?
这是我的代码
@implementation Professional
{
NSMutableArray *updatedLocalityArray; // alloc,init did in viewDidLoad
NSString *toCheck;
}
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
UITableViewCell *tableViewCell = [tableView cellForRowAtIndexPath:indexPath];
NSLog(@"%@",tableViewCell.textLabel.text);
toCheck = tableViewCell.textLabel.text;
[updatedLocalityArray addObject:toCheck];
NSLog(@"%@ *****", updatedLocalityArray);
}
- (void)tableView:(UITableView *)tableView didDeselectRowAtIndexPath:(NSIndexPath *)indexPath
{
UITableViewCell *tableViewCell = [tableView cellForRowAtIndexPath:indexPath];
NSLog(@"%@",tableViewCell.textLabel.text);
for (NSString *test in updatedLocalityArray)
{
if ([test isEqualToString:tableViewCell.textLabel.text])
{
[updatedLocalityArray removeObject:test];
NSLog(@"%@ *****", updatedLocalityArray);
}
}
}
答案 0 :(得分:16)
在迭代时,您无法从NSMutableArray
删除项目。
有几种解决方案:
或
for
循环而不是for each
语法。不复制数组可以节省分配和几个CPU周期:
for (int i = updatedLocalityArray.count-1 ; i >= 0 ; i--)
{
NSString *test = updatedLocalityArray[i];
if ([test isEqualToString:tableViewCell.textLabel.text])
{
[updatedLocalityArray removeObjectAtIndex:i];
NSLog(@"%@ *****", updatedLocalityArray);
}
}
答案 1 :(得分:3)
在tableview deselect方法中,您写道:
for (NSString *test in updatedLocalityArray)
{
if ([test isEqualToString:tableViewCell.textLabel.text])
{
[updatedLocalityArray removeObject:test];
NSLog(@"%@ *****", updatedLocalityArray);
}
}
在该代码中,您通过updatedLocalityArray
枚举,如果找到匹配项,则从同一数组中删除该对象,此逻辑导致此问题。为了修复您需要创建本地副本并对其进行更改并在枚举后将其分配回原始数组。
NSMutableArray *tempArray = [updatedLocalityArray mutableCopy];
for (NSString *test in updatedLocalityArray)
{
if ([test isEqualToString:tableViewCell.textLabel.text])
{
[tempArray removeObject:test];
NSLog(@"%@ *****", tempArray);
}
}
updatedLocalityArray = tempArray;
答案 2 :(得分:1)
如果您当前的数组是B
,则可以复制另一个名为B
的相同数组,然后您可以枚举A
并运行NSMutableArray *tempArray = someArray.mutableCopy;
,然后它就不会崩溃。
枚举时不能修改容器。
import calendar
months = filter(None, calendar.month_name)
答案 3 :(得分:0)
如果您当前的数组是A,您可以复制另一个名为B的相同数组,然后您可以枚举B并操作A,然后它就不会崩溃。
答案 4 :(得分:-1)
使用for...in...
控制语句循环遍历数组时,无法修改数组。
尝试:
NSArray *compareArray = [updatedLocalityArray copy];
for (NSString *test in compareArray)
// ...