实现目的:tableview刷新页面,原来是10条数据,刷新后只有3条。并且tableview的原来的contentInset
self.tableView.contentInset =UIEdgeInsetsMake(100.0f,0.0f, 0.0f, 0.0f);
刷新后变成self.tableView.contentInset =UIEdgeInsetsMake(0.0f,0.0f, 0.0f, 0.0f);
错误描述:数组越界。
2014-04-25 17:27:11.194 LasyTableViewImages[2168:70b] *** Terminating app due to uncaught exception 'NSRangeException', reason: '*** -[__NSArrayM objectAtIndex:]: index 4 beyond bounds [0 .. 2]'
很神奇的是,当我换成3.5寸屏的时候就不会报错。而换成4寸屏就报错了。查找原因之后发现重要的是这两句代码的顺序:
self.tableView.contentInset =UIEdgeInsetsMake(0.0f,0.0f, 0.0f, 0.0f);
//tableView刷新数据
self.tableViewreloadData];
如果像上面那样写就会报错,顺序换一下就对了。仔细想了一下,明白了。当我先设置contentInset的时,tableview要像上移动。由于要滚动,有新的行要显示到窗口,所以将首先调用
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
这个方法。而移动之前屏幕上显示出了4条数据。也就是我将要显示的数据是第5条,即indexPath.row = 4 的那一条。在这个方法里有语句:[_dataArrayobjectAtIndex:indexPath.row]
而此时,_dataArray的元素只有3个,而indexPath==4。所以肯定数组越界。顺序反过来就不一样了。 先执行reloadData方法,接下来会先更新数据源,也就是先执行numberOfRowsInSection这些方法。这样,tableview已经知道它要显示的行数,
然后再执行cellForRow就不会出错了!所以搞清楚方法执行顺序很重要。