iOS边练边学--多线程练习的多图片下载 以及 使用第三方框架(SDWebImage)的多图片下载
一、自己实现多图片下载应该注意的问题
- 沙盒缓存的问题
- 程序缓存的问题
- cell重复利用显示图片混乱的问题 -- 用户拖拽快,下载图片慢导致的
- 解决图片混乱引入NSOperation集合的问题
- 资源下载失败的问题(练习中没有出现过,但是一定要考虑)
#import "ChaosViewController.h"
#import "ChaosApp.h" @interface ChaosViewController ()
/** 模型集合 */
@property(nonatomic,strong) NSMutableArray *apps;
/** 图片缓存 */
@property(nonatomic,strong) NSMutableDictionary *imageCache; /** queue */
@property(nonatomic,strong) NSOperationQueue *queue; /** 所有的操作对象 */
@property(nonatomic,strong) NSMutableDictionary *opeartions; @end @implementation ChaosViewController - (NSMutableDictionary *)opeartions
{
if (_opeartions == nil) { _opeartions = [NSMutableDictionary dictionary]; }
return _opeartions;
} - (NSOperationQueue *)queue
{
if (_queue == nil) { // 设置最大线程数
_queue.maxConcurrentOperationCount = ; _queue = [[NSOperationQueue alloc] init];
}
return _queue;
} - (NSMutableDictionary *)imageCache
{
if (_imageCache == nil) { _imageCache = [NSMutableDictionary dictionary];
}
return _imageCache;
} - (NSMutableArray *)apps
{
if (_apps == nil) { _apps = [NSMutableArray array]; NSString *path = [[NSBundle mainBundle] pathForResource:@"apps.plist" ofType:nil];
NSArray *arrDict = [NSArray arrayWithContentsOfFile:path]; for (NSDictionary *dict in arrDict) {
ChaosApp *app = [ChaosApp appWithDict:dict];
[_apps addObject:app];
}
} return _apps;
} - (void)viewDidLoad {
[super viewDidLoad];
} #pragma mark - Table view data source - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section { return self.apps.count;
} - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"app"]; ChaosApp *app = self.apps[indexPath.row]; cell.textLabel.text = app.name;
cell.detailTextLabel.text = app.download; UIImage *image = self.imageCache[app.icon]; if (image) { // 缓存中有图片 cell.imageView.image = image; } else { // 缓存中没有,系统沙盒中找图片 // 获取Library\Cache文件
NSString *cachePath = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) lastObject];
// 获取要获取图片的名称
NSString *fileName = [app.icon lastPathComponent];
// 拼接图片文件路径
NSString *fullPath = [cachePath stringByAppendingPathComponent:fileName]; // 通过图片全路径得到NSData
NSData *data = nil;// [NSData dataWithContentsOfFile:fullPath]; if (data) { // 沙盒中有图片 cell.imageView.image = [UIImage imageWithData:data]; } else { // 沙盒Cache文件中也没有
// 设置站位图片 -- 作用:系统的imageView默认没有尺寸,如果第一张图片还没显示出来,用户拖拽之后再回来,图片下载完成也不会显示了。其实imageview已经有图片了,只不过imageView没有尺寸看不见。
cell.imageView.image = [UIImage imageNamed:@"placeholder"]; NSOperation *operation = self.opeartions[app.icon]; // 从操作集合中取出对应图片的operation
if (operation == nil) {
operation = [NSBlockOperation blockOperationWithBlock:^{ // 下载图片
NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:app.icon]]; if (data == nil) {
[self.opeartions removeObjectForKey:app.icon];
return;
} UIImage *image = [UIImage imageWithData:data];
// [NSThread sleepForTimeInterval:1.0]; // 线程睡一秒之后,cell图片出现了混乱
// 将下载的图片存入到缓存集合中,app.icon作为键 image作为值
self.imageCache[app.icon] = image; [[NSOperationQueue mainQueue] addOperationWithBlock:^{
// 回到主线程显示图片
[tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationNone];
}]; // 将图片写入沙盒Cache文件中
[data writeToFile:fullPath atomically:YES]; [self.opeartions removeObjectForKey:app.icon];
}];
} [self.queue addOperation:operation];
self.opeartions[app.icon] = operation;
}
}
return cell;
} @end
二、使用SDWebImage框架之后,上面所有的担心都不用考虑。

iOS边练边学--多线程练习的多图片下载 以及 使用第三方框架(SDWebImage)的多图片下载的更多相关文章
- iOS边练边学--多线程介绍、NSThread的简单实用、线程安全以及线程之间的通信
一.iOS中的多线程 多线程的原理(之前多线程这块没好好学,之前对多线程的理解也是错误的,这里更正,好好学习这块) iOS中多线程的实现方案有以下几种 二.NSThread线程类的简单实用(直接上代码 ...
- iOS边练边学--多线程NSOperation介绍,子类实现多线程的介绍(任务和队列),队列的取消、暂停(挂起)和恢复,操作依赖与线程间的通信
一.NSOperation NSOperation和NSOperationQueue实现多线程的具体步骤 先将需要执行的操作封装到一个NSOperation对象中 然后将NSOperation对象添加 ...
- iOS边练边学--Http网络再学习,简单介绍
一.URL 什么是URL URL中常见的协议 二.Http Http的基本通信过程 发送Http请求的方法 GET 和 POST 对比 GET 和 POST 的选择 三.iOS中的Http学习 iOS ...
- iOS边练边学--CALayer,非根层隐式动画,钟表练习
一.CALayer UIView之所以能显示在屏幕上,完全是因为他内部的一个图层 在创建UIView对象时,UIView内部会自动创建一个图层(即CALayer对象),通过UIView的layer属性 ...
- iOS边练边学--UIGestureRecognizer手势识别器简单介绍
iOS 3.2之后,苹果退出了手势识别功能(Gesture Recognizer),在触摸事件处理方面,大大简化了开发者的开发难度. 一.UIGestureRecognizer UIGestureRe ...
- iOS边练边学--触摸事件以及能够拖拽的UIView的练习
一.用户在使用APP的过程中,会产生各种各样的事件.iOS中的事件可以分为3大类型: 二.响应者对象 在iOS中只有继承了了UIResponder的对象才能接受并处理事件,这样的对象称之为“响应者对象 ...
- iOS边练边学--应用数据存储的常用方式(plist,Preference,NSKeyedArchiver)其中的三种
iOS应用数据存储的常用方式: XML属性列表(plist)归档 Preference(偏好设置) NSKeyedArchiver归档(NSCoding) SQLite3--这里暂且不讲 Core D ...
- iOS边练边学--图片的拉伸
图片拉伸方法一: IOS 5.0以后才有的方法: - (void)viewDidLoad { [super viewDidLoad]; UIImageView *imageView = [[UIIma ...
- iOS边练边学--NSURLSessionDataTask实现文件真正的断点续传
实现重点: NSURLSessionDataTask要设置请求头,从路径中获取文件已经下载的长度(文件没有下载过的话,长度为0).通过这个长度设置请求的Range 如图: 接收到请求的时候key:文件 ...
随机推荐
- 第24章 SEH结构化异常处理_异常处理及软件异常
24.1 程序的结构 (1)try/except框架 __try{ //被保护的代码块 …… } __except(except fileter/*异常过滤程序*/){ //异常处理程序 } (2) ...
- NGUI:HUD Text(头顶伤害漂浮文字)
HUD Text 很早之前就有闻于NGUI中的HUD Text插件,今天得以尝试,看了会儿官方的文档,楞是没给看明白,官方的ReadMe.txt写的使用方法如下: 官网Usage 1. Attach ...
- Linux安装telnet
安装环境:CentOS 6.4 上篇已经讲述了memcached的安装,现在要测试Memcached功能的时候,需要使用到telnet服务.于是就有了本篇. 一.安装telnet 1.检测t ...
- 转:Metronic – 超赞!基于 Bootstrap 的响应式后台管理模板
http://www.cnblogs.com/lhb25/p/metronic-responsive-admin-dashboard-template.html
- javascript中的迭代器
1.forEach迭代器 forEach方法接收一个函数作为参数,对数组中每个元素使用这个函数,只调用这个函数,数组本身没有任何变化 //forEach迭代器 function square(num) ...
- iOS数组使用
相关链接: ios数组基本用法和排序 NSArray 排序汇总 iOS 数组排序方法 IOS-筛选数组内的元素 关于EnumerateObjectsUsingBlock和for-in之间的较量 [iO ...
- SQL 数据结构操作语句
修改字段 exec sp_rename '表名.[字段名]','新字段名','column' alter table tab_info rename column createname to this ...
- JavaScript中浏览器兼容问题
浏览器兼容性问题是在实际开发中容易忽略而又最重要的一部分.我们在讲老版本浏览器兼容问题之前,首先要了解什么是能力检测,它是来检测浏览器有没有这种能力,即判断当前浏览器是否支持要调用的属性或者方法.下面 ...
- Linux 图形化操作
//Linux图形化操作 #include <stdio.h> #include <stdlib.h> #include <string.h> #include & ...
- ASP.NET中进行消息处理(MSMQ) 一
MSMQ是微软消息队列的英文缩写.那么什么是消息队列?这些介绍网上一大片这里就不多说了.本文对于大虾级的人物来说这只是小玩意而已,对于初学者来说这文章还是有一定的帮助,希望路过的大虾们别笑话我班门弄斧 ...