如何解决reloadRowsAtIndexPaths是否停止加载UITableViewCells?
| 我正在尝试将favicon合并到UITableView中。该表基本上可以获取网站,我想在右侧显示该图标。我最初在右侧放置了一个占位符图标,并在后台运行一个函数。此功能获取网站的URL,对其进行解析并尝试查找该图标。如果找不到,则保留相同的占位符图像;否则,它将替换为网站的网站图标。最初,我尝试使用[tableView reloadData]在模拟器中运行良好,但是它确实做了奇怪而又不可靠的事情(例如,它将创建一些单元格,但是留下一个巨大的空白单元格)。无论如何,我偶然发现了reloadRowsAtIndexPaths,似乎需要使用该函数。但是,结果仍然非常不可靠。我的提取功能在后台运行,如下所示:- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
...//other code here for showing website labels
//obtain the favicon.ico
if(!this_article.iconLoaded){
this_article.iconLoaded = TRUE;
NSDictionary *args = [NSDictionary dictionaryWithObjectsAndKeys:this_article,@\"article\",indexPath,@\"indexPath\",nil];
[self performSelectorInBackground:@selector(fetchFaviconWrapper:) withObject:args];
}
cell.favicon.image = this_article.icon;
return cell;
}
在FetchFaviconWrapper中:
- (void)fetchFaviconWrapper:(NSDictionary *)args {
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
[self fetchFavicon:[args objectForKey:@\"article\"]];
NSArray *paths = [NSArray arrayWithObject:[args objectForKey:@\"indexPath\"]];
[articleTable beginUpdates];
[articleTable reloadRowsAtIndexPaths:paths withRowAnimation:UITableViewRowAnimationFade];
[articleTable endUpdates];
[pool release];
}
基本上,fetchFavicon拥有一个网站,取得主机URL,附加\“ / favicon.ico \”,将其构造为NSData对象,然后查找图像(如果存在)。但是,这也相当不可靠。在后台运行线程时替换占位符图像的最佳方法是什么?我可以在主线程上做所有事情,但这只会使表加载缓慢。我似乎忽略了某些东西,或者我只是忘记添加了一些东西……只是无法弄清楚。
解决方法
目前尚不清楚您是否正在从单独的线程访问和修改UI。
如果是这样,这就是您不可靠的原因。只能从主线程访问UIKit。如果您有兴趣,可以在S.O.上找到许多问题。以及网络上的许多讨论。
如果您想保留第二个线程,则有一个解决方法。实际上,您可以使用以下命令将消息发送到UI对象:
-performSelectorOnMainThread:withObject:waitUntilDone:
而不是直接从辅助线程发送它们。
如果此解决方法不能为您解决问题,则建议您重新设计您的应用程序,以使辅助线程仅访问您的模型,而不访问UI。修改UI的所有操作都应在主线程上执行。如果模型准备好后需要在桌子上呼叫reloadData
,可以使用performSelectorOnMainThread:withObject:waitUntilDone
进行。
, 我建议一些事情。
附加./favicon.ico并不总是准确的。研究向站点添加图标以支持它们的各种方法。
至于替换默认的占位符,我建议使用ѭ5通知主线程何时进行更改。
, 我绝对会重申后台线程没有用户界面。
更改您的初始代码:
- (void)fetchFaviconWrapper:(NSDictionary *)args {
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
[self fetchFavicon:[args objectForKey:@\"article\"]];
NSArray *paths = [NSArray arrayWithObject:[args objectForKey:@\"indexPath\"]];
[articleTable beginUpdates];
[articleTable reloadRowsAtIndexPaths:paths
withRowAnimation:UITableViewRowAnimationFade];
[articleTable endUpdates];
[pool release];
}
为此,看看您是否仍然有问题
- (void)fetchFaviconWrapper:(NSDictionary *)args {
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
[self fetchFavicon:[args objectForKey:@\"article\"]];
NSArray *paths = [NSArray arrayWithObject:[args objectForKey:@\"indexPath\"]];
[self performSelectorOnMainThread:@selector(reloadData)
withObject:nil
waitUntilDone:YES];
[pool release];
}
在这种情况下,waitUntilDone是无关紧要的,它的首选形式是YES。
当您具有时髦的单元格行为时,另一个值得怀疑的问题是您是否正确处理了单元格重用。您没有向我们显示该代码,所以我们无法告诉。如果您要在某个位置保留对某个单元格的引用,然后将图像数据设置为该单元格,则当表格将单元格从您的下方重复使用时,您会感到不便。 (在这种情况下,我认为这不是问题。)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。