异步加载图片等数据

本文介绍了一种在UITableView中高效加载图片的方法,通过缓存已加载的图片并在加载新图片时使用异步下载来提升用户体验。该方法首先尝试从缓存中获取图片,若缓存中没有,则异步下载并更新缓存。

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


大致思路为两步:(1) 加载tableView时读取图片缓存,如果存在则显示,如果不存在则异步下载;(2) 下载图片信息成功,更新图片缓存,重新加载tableView的数据
示例代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
/* 其他代码 */
 
// 用户头像
UIImage *userPic = [self cachedImageForUrl:[NSURL URLWithString:url]];
cell.userPicView.image = userPic;
 
/* 其他代码 */
}
 
- (UIImage *)cachedImageForUrl:(NSURL *)url {
id cachedObject = [self.cachedImage objectForKey:url];
if (cachedObject == nil) {
//防止reloadData时重复提交请求,添加占位符
[self.cachedImage setObject:@"Loading..." forKey:url];
//异步下载图片
ASIHTTPRequest *picRequest = [ASIHTTPRequest requestWithURL:url];
picRequest.delegate = self;
picRequest.didFinishSelector = @selector(didFinishRequestImage:);
picRequest.didFailSelector   = @selector(didFailRequestImage:);
[self.queue addOperation:picRequest];
// 更新状态栏的网络标示
[UIApplication sharedApplication].networkActivityIndicatorVisible = YES;
}else if ( ![cachedObject isKindOfClass:[UIImage class]] ) {
cachedObject = nil;
}
return cachedObject;
}
 
- (void)didFinishRequestImage:(ASIHTTPRequest *)request {
NSData *imageData = [request responseData];
UIImage *image = [UIImage imageWithData:imageData];
if (image != nil) {
[self.cachedImage setObject:image forKey:request.url];
[self.tableView reloadData];
}
[UIApplication sharedApplication].networkActivityIndicatorVisible = NO;
}
 
- (void)didFailRequestImage:(ASIHTTPRequest *)request {
NSLog(@"Error Download Image: %@", request.error);
[UIApplication sharedApplication].networkActivityIndicatorVisible = NO;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值