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。 当您具有时髦的单元格行为时,另一个值得怀疑的问题是您是否正确处理了单元格重用。您没有向我们显示该代码,所以我们无法告诉。如果您要在某个位置保留对某个单元格的引用,然后将图像数据设置为该单元格,则当表格将单元格从您的下方重复使用时,您会感到不便。 (在这种情况下,我认为这不是问题。)     

要回复问题请先登录注册