终止应用程序由于未捕获的异常“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

+0

你在beginUpdates和endUpdates方法块之间更新什么?为什么你需要调用这两种方法? – Suryakant

+1

我很好奇不同的表视图引用。你从NSLog看到了什么(@“Property%@,Variable%@”,self.myTableView,myTableView);'? –

+3

不知何故,您的tabelview数据源自上次重新加载后发生了变化。上次重新载入它时,现在有7个数据段(当您可以开始/结束时),数据源数组中只有一个数据元素。确保你没有修改数据源而不更新tableview。 – Putz1103

取而代之的是:

[self.myTableView beginUpdates]; 
[myTableView endUpdates]; 

试试这个:

[self.myTableView beginUpdates]; 
[self.myTableView endUpdates]; 

我怀疑endUpdates是没有得到所谓的在你的myTableView财产。 beginUpdates然而,这会导致:

  1. 不平衡beginUpdates/endUpdates电话和
  2. 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表我认为这将是罚款。

+0

'[myTable的reloadData ]根据doc的说法,它根本不是低效的:“为了提高效率,表格视图只会重新显示那些可见的行。” –