2013-10-14 200 views
5

我解析XML文件,并把它的分析值在表view.The表视图只有一个section.But我得到以下异常:断言失败 - [UITableView的_endCellAnimationsWithContext]

2013-10 -14 15:21:57.250 tableview [6068:907] *声明失败 - [UITableView _endCellAnimationsWithContext:],/ SourceCache /UIKit/UIKit-2380.17/UITableView.m:909 2013-10-14 15:22:11.227 tableview [6068:907] 由于未捕获的异常'NSInternalInconsistencyException'而终止应用程序,原因是:'试图将0行插入到0节中,但更新后0节中只有0行' * *第一掷调用堆栈: (0x33e752a3 0x3bcde97f 0x33e7515d 0x3474aab7 0x35cb0a9f 0x35de6b27 0x6a10f 0x69ce5 0x33dc6037 0x346dc599 0x6b54b 0x3478c0f5 0x33e4a683 0x33e49ee9 0x33e48cb7 0x33dbbebd 0x33dbbd49 0x379702eb 0x35cd1301 0x68bdd 0x68b64) 的libC++ abi.dylib:终止叫做抛出异常

的代码是:

/** 
The NSOperation "ParseOperation" calls addFiles: via NSNotification, on the main thread which in turn calls this method, with batches of parsed objects. The batch size is set via the kSizeOfEarthquakeBatch constant. 
*/ 
- (void)addFilesToList:(NSArray *)files { 

    NSInteger startingRow = [self.fileList count]; 
    NSLog(@"STARTING ROW:%d",startingRow); 
    NSInteger fileCount = [files count]; 
    NSLog(@"FILE COUNT : %d",fileCount); 
    NSMutableArray *indexPaths = [[NSMutableArray alloc] initWithCapacity:fileCount]; 
    NSLog(@"INDEX PATHS:%@",indexPaths); 
    for (NSInteger row = startingRow; row < (startingRow + fileCount); row++) { 
     NSLog(@"into for"); 

     NSIndexPath *indexPath = [NSIndexPath indexPathForRow:row inSection:0]; 
     NSLog(@"INDEXPAth %@",indexPath); 
     [indexPaths addObject:indexPath]; 
    } 

    [self.fileList addObjectsFromArray:files]; 
    NSLog(@"ADD objects"); 
    NSLog(@"FILELIST:%@",self.fileList); 

    //GETTING EXCEPTION AT THIS LINE 

    [self.tableview insertRowsAtIndexPaths:indexPaths withRowAnimation:UITableViewRowAnimationAutomatic]; 
} 


#pragma mark - UITableViewDelegate\ 

-(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView 
{ 
    return 1; 
} 

// The number of rows is equal to the number of earthquakes in the array. 
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section { 

    return [self.fileList count]; 
    NSLog(@"NUMBER OF ROWS :%d",[self.fileList count]); 
} 

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { 

    static NSString *kFileCellID = @"Cell"; 
    myTableCell *cell = (myTableCell *)[tableView dequeueReusableCellWithIdentifier:kFileCellID]; 

    // Get the specific earthquake for this row. 
    fileList *file = (self.fileList)[indexPath.row]; 

    [cell configureWithFile:file]; 
    return cell; 
} 

回答

1

在我的情况下,问题是我使用了两个indexPath(indexPath,lastIndexPath)。但对于lastIndexPath.row已超出我的数组bound.solve通过检查condition.hope这有助于某人。

[self.tableView reloadRowsAtIndexPaths:[NSArray arrayWithObjects:indexPath, lastIndexPath, nil] withRowAnimation:UITableViewRowAnimationAutomatic]; 
+0

@Megha。谢谢。 –

12

正在发生的事情是,你在添加新的细胞,其实现代码如下仍然不知道做了self.fileList阵列的变化。 UIKit将添加新单元格并检查段计数的顺序不幸无法控制。 但是为了解决这个问题,UItableview插入和删除操作需要被包装在startsUpdate和endsUpdate方法上。

[self.tableView beginUpdates]; 

// Do all the insertRowAtIndexPath and all the changes to the data source array 

[self.tableView endUpdates]; 
+0

谢谢你 - 这并获得成功的我! – mdebeus

0

我在更新API调用后的行。

尝试更新主线程内的行。 (因为所有UI更新都应该在主线程内完成)。

试试这个....

DispatchQueue.main.async { 
    self.tableView.insertRows(at: [newIndexPath], with: .bottom) 
}