终止应用程序由于未捕获的异常“NSInternalInconsistencyException”
如果用户触摸UITableView
,只是更新TableView
为下面的代码终止应用程序由于未捕获的异常“NSInternalInconsistencyException”
[self.myTableView beginUpdates];
[myTableView endUpdates];
那么它产生以下崩溃报告。
2013-12-17 17:27:33.446 planobot[12300:a0b] *** Assertion failure in -[UITableView _endCellAnimationsWithContext:], /SourceCache/UIKit_Sim/UIKit-2903.23/UITableView.m:1330
2013-12-17 17:27:33.469 planobot[12300:a0b] *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Invalid update: invalid number of rows in section 0. The number of rows contained in an existing section after the update (1) must be equal to the number of rows contained in that section before the update (7), plus or minus the number of rows inserted or deleted from that section (0 inserted, 0 deleted) and plus or minus the number of rows moved into or out of that section (0 moved in, 0 moved out).'
*** First throw call stack:
(
0 CoreFoundation 0x0210e5e4 __exceptionPreprocess + 180
1 libobjc.A.dylib 0x01e918b6 objc_exception_throw + 44
2 CoreFoundation 0x0210e448 +[NSException raise:format:arguments:] + 136
3 Foundation 0x00fe5fee -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 116
4 UIKit 0x0024485d -[UITableView _endCellAnimationsWithContext:] + 13402
5 UIKit 0x00253caa -[UITableView endUpdatesWithContext:] + 51
6 UIKit 0x00253cd8 -[UITableView endUpdates] + 41
7 planobot 0x0004f34a -[DailyReportViewController tableView:didSelectRowAtIndexPath:] + 1658
8 UIKit 0x002557b1 -[UITableView _selectRowAtIndexPath:animated:scrollPosition:notifyDelegate:] + 1513
9 UIKit 0x00255924 -[UITableView _userSelectRowAtPendingSelectionIndexPath:] + 279
10 UIKit 0x00259908 __38-[UITableView touchesEnded:withEvent:]_block_invoke + 43
11 UIKit 0x00190183 ___afterCACommitHandler_block_invoke + 15
12 UIKit 0x0019012e _applyBlockToCFArrayCopiedToStack + 403
13 UIKit 0x0018ff5a _afterCACommitHandler + 532
14 CoreFoundation 0x020d64ce __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 30
15 CoreFoundation 0x020d641f __CFRunLoopDoObservers + 399
16 CoreFoundation 0x020b4344 __CFRunLoopRun + 1076
17 CoreFoundation 0x020b3ac3 CFRunLoopRunSpecific + 467
18 CoreFoundation 0x020b38db CFRunLoopRunInMode + 123
19 GraphicsServices 0x02fec9e2 GSEventRunModal + 192
20 GraphicsServices 0x02fec809 GSEventRun + 104
21 UIKit 0x00173d3b UIApplicationMain + 1225
22 planobot 0x000a6a4d main + 141
23 planobot 0x000022b5 start + 53
)
libc++abi.dylib: terminating with uncaught exception of type NSException
为什么应用程序会抛出NSInternalInconsistencyException
?
取而代之的是:
[self.myTableView beginUpdates];
[myTableView endUpdates];
试试这个:
[self.myTableView beginUpdates];
[self.myTableView endUpdates];
我怀疑endUpdates
是没有得到所谓的在你的myTableView
财产。 beginUpdates
然而,这会导致:
- 不平衡
beginUpdates
/endUpdates
电话和 NSInternalInconsistencyException
我常常看到这样的时候,我算不正确。在此基础上:
reason: 'Invalid update: invalid number of rows in section 0. The number of rows contained in an existing section after the update (1) must be equal to the number of rows contained in that section before the update (7), plus or minus the number of rows inserted or deleted from that section (0 inserted, 0 deleted) and plus or minus the number of rows moved into or out of that section (0 moved in, 0 moved out).'
我猜,你的表中它有7个元素(如tableView:numberOfRowsInSection:
报道)返航7,现在正在返回1.这使我相信的,你觉得叫
[self.myTableView beginUpdates];
[myTableView endUpdates];
当您删除行时就足够了。
但是你需要告诉你UITableView首先删除(或添加)了哪些行。 这将取决于您的确切情况,但如果您想要删除第零部分的前七行,它将看起来像这样。
NSMutableArray *indexes = [[NSMutableArray alloc] init];
for (int i = 0; i <= 6; i++)
{
[indexes addObject:[NSIndexPath indexPathForItem:i inSection:0]];
}
[myTable beginUpdates];
[myTable deleteRowsAtIndexPaths:indexes withRowAnimation:NO];
[myTable endUpdates];
另外,作为@Marco说,只要使用相同的指针到表,否则这是一个有点混乱,我在我的例子一样。
或者,如果你只是想告诉你表完整地重新加载,你可以调用reloadData instaed。
[myTable reloadData];
我认为这将是不太有效的手动指定哪些行被添加或删除,但在7表我认为这将是罚款。
'[myTable的reloadData ]根据doc的说法,它根本不是低效的:“为了提高效率,表格视图只会重新显示那些可见的行。” –
你在beginUpdates和endUpdates方法块之间更新什么?为什么你需要调用这两种方法? – Suryakant
我很好奇不同的表视图引用。你从NSLog看到了什么(@“Property%@,Variable%@”,self.myTableView,myTableView);'? –
不知何故,您的tabelview数据源自上次重新加载后发生了变化。上次重新载入它时,现在有7个数据段(当您可以开始/结束时),数据源数组中只有一个数据元素。确保你没有修改数据源而不更新tableview。 – Putz1103