cell中延迟加载

本文介绍了如何优化iOS应用中图片加载性能,通过按需加载和后台线程处理计算任务,避免阻塞主线程,提升用户体验。文章详细解释了如何在`tableView`中实现图片按需加载,以及在需要长时间计算时如何利用后台线程避免程序假死状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

常我们会用tableView显示很多条目, 有时候需要显示图片, 但是一次从服务器上取来所有图片对用户来浪费流量,对服务器也是负担.最好是按需加载,即当该用户要浏览该条目时再去加载它的图片.

重写如下方法
- (void)tableView:(UITableView *)tableViewwillDisplayCell:(UITableViewCell *)cellforRowAtIndexPath:(NSIndexPath *)indexPath
{
 
   UIImage*image = [selfgetImageForCellAtIndexPath:indexPath];  //从网上取得图片
    [cell.imageViewsetImage:image];
}

这虽然解决了延时加载的问题, 但当网速很慢,或者图片很大时(假设,虽然一般cell中的图很小),你会发现程序可能会失去对用户的响应.
原因是UIImage *image = [self getImageForCellAtIndexPath:indexPath];这个方法可能要花费大量的时间,主线程要处理这个method.
所以失去了对用户的响应.

所以要将该方法提出来:
- (void)updateImageForCellAtIndexPath:(NSIndexPath*)indexPath
{
    NSAutoreleasePool*pool = [[NSAutoreleasePool alloc] init];
    UIImage*image = [self getImageForCellAtIndexPath:indexPath];
    UITableViewCell*cell = [self.tableView cellForRowAtIndexPath:indexPath];
    [cell.imageViewperformSelectorOnMainThread:@selector(setImage:) withObject:imagewaitUntilDone:NO];
    [poolrelease];
}
然后再新开一个线程去做这件事情
- (void)tableView:(UITableView *)tableViewwillDisplayCell:(UITableViewCell *)cellforRowAtIndexPath:(NSIndexPath *)indexPath
{
    [NSThreaddetachNewThreadSelector:@selector(updateImageForCellAtIndexPath:)toTarget:self withObject:indexPath];
}

同理当我们需要长时间的计算时,也要新开一个线程去做这个计算以避免程序处于假死状态

以上代码只是示例, 还可以改进的更多, 比如从网上down下来一次后就将图片缓存起来,再次显示的时候就不用去下载.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值