iOS多圖下載案例(三)

利用多線程進行優(yōu)化

#import"ViewController.h"

#import"App.h"

@interfaceViewController()

@property(nonatomic,strong)NSArray*apps;

//內存緩存

@property(nonatomic,strong)NSMutableDictionary*imageDic;

@property(nonatomic,strong)NSOperationQueue*queue;

@property(nonatomic,strong)NSMutableDictionary*operation;

@end

@implementationViewController

- (NSMutableDictionary*)operation{

if(_operation==nil) {

_operation= [NSMutableDictionarydictionary];

}

return_operation;

}

- (NSOperationQueue*)queue{

if(_queue==nil) {

_queue= [[NSOperationQueuealloc]init];

//設置最大并發(fā)數(shù)

_queue.maxConcurrentOperationCount=5;

}

return_queue;

}

- (NSMutableDictionary*)imageDic{

if(_imageDic==nil) {

_imageDic= [NSMutableDictionarydictionary];

}

return_imageDic;

}

- (NSArray*)apps{

if(_apps==nil) {

NSArray*ary = [NSArrayarrayWithContentsOfFile:[[NSBundlemainBundle]pathForResource:@"apps"ofType:@"plist"]];

NSMutableArray*ary1 = [NSMutableArrayarray];

for(NSDictionary*dicinary) {

[ary1addObject:[AppappWithdic:dic]];

}

_apps= ary1;

}

return_apps;

}

- (NSInteger)tableView:(UITableView*)tableView numberOfRowsInSection:(NSInteger)section{

returnself.apps.count;

}

- (NSInteger)numberOfSectionsInTableView:(UITableView*)tableView{

return1;

}

- (UITableViewCell*)tableView:(UITableView*)tableView cellForRowAtIndexPath:(NSIndexPath*)indexPath{

staticNSString* ID =@"app";

UITableViewCell*cell =[tableViewdequeueReusableCellWithIdentifier:ID];

App*app =_apps[indexPath.row];

cell.textLabel.text= app.name;

cell.detailTextLabel.text=app.download;

//下載圖片

//先查看圖片在內存緩存中是否存在久橙,如果存在儒鹿,直接拿來用潮瓶,但程序重新啟動時浮庐,還要重新下載

//如果有磁盤緩存把磁盤緩存放到內存緩存,否則直接下載

//1.沒有下載過

//2.下載過被銷毀了

UIImage*imaged = [self.imageDicobjectForKey:app.icon];

if(imaged) {

cell.imageView.image=imaged;

NSLog(@"%ld---內存緩存",(long)indexPath.row);

}else{

NSString*Caches =NSSearchPathForDirectoriesInDomains(NSCachesDirectory,NSUserDomainMask,YES).lastObject;

NSString*filename = [app.iconlastPathComponent];

NSString* fullpath = [CachesstringByAppendingPathComponent:filename];

//檢查磁盤緩存:

NSData*imageD = [NSDatadataWithContentsOfFile:fullpath];

if(imageD) {

UIImage*image = [UIImageimageWithData:imageD];

cell.imageView.image=image;

NSLog(@"%ld---磁盤緩存",(long)indexPath.row);

//把磁盤緩存放到內存緩存

[self.imageDicsetObject:imageforKey:app.icon];

}else{

//檢查該操作是否在緩存中霜威,如果是就什么也不做

NSBlockOperation*download = [self.operationobjectForKey:app.icon];

if(download) {

}else{

//先清空image,放個占位的圖片

cell.imageView.image=[UIImageimageNamed:@"Snip20170530_1"];

download = [NSBlockOperationblockOperationWithBlock:^{

NSURL*url = [NSURLURLWithString:app.icon];

NSData*imageData = [NSDatadataWithContentsOfURL:url];

UIImage*image = [UIImageimageWithData:imageData];

//容錯處理比藻,防止url不正確绿语,或者網(wǎng)絡問題

if(image ==nil){

[self.operationremoveObjectForKey:app.icon];

return;

}

//演示網(wǎng)速慢的情況

[NSThreadsleepForTimeInterval:3.0];

NSLog(@"dowunload--%@",[NSThreadcurrentThread]);

//線程間通信

[[NSOperationQueuemainQueue]addOperationWithBlock:^{

//刷新某一行

[self.tableViewreloadRowsAtIndexPaths:@[indexPath]withRowAnimation:UITableViewRowAnimationLeft];

cell.imageView.image=image;

}];

//把圖片保存在內存緩存里

[self.imageDicsetObject:imageforKey:app.icon];

[imageDatawriteToFile:fullpathatomically:YES];

NSLog(@"%ld",(long)indexPath.row);

//移除圖片的下載緩存

[self.operationremoveObjectForKey:app.icon];

}];

//添加操作到操作緩存中

[self.operationsetObject:downloadforKey:app.icon];

//添加操作到隊列

[self.queueaddOperation:download];

}

}

}

//打印沙盒路徑

//NSLog(@"%@",NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES));

returncell;

}

//UI很不流暢-》開子線程下載

//圖片重復下載-》緩存

//內存緩存-》磁盤緩存

//圖片不會刷新:手動刷新,因為圖片尺寸為0

//圖片數(shù)據(jù)錯亂

//圖片重復下載:當圖片還為完全下載之前记劝,又要重新展示圖片

//documents:手機連上itunes會備份变姨,不允許把緩存數(shù)據(jù)放到這個路徑。

//library:緩存路徑:保存緩存數(shù)據(jù)偏好設置:保存一些賬號信息

//tmp:臨時路徑厌丑,隨時會被刪除

@end

//如果出現(xiàn)內存警告

- (void)didReceiveMemoryWarning{

//不會影響圖片顯示

[self.imageDicremoveAllObjects];

//取消隊列中所有操作

[self.queuecancelAllOperations];

}

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末定欧,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子怒竿,更是在濱河造成了極大的恐慌砍鸠,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件耕驰,死亡現(xiàn)場離奇詭異爷辱,居然都是意外死亡,警方通過查閱死者的電腦和手機朦肘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進店門饭弓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人媒抠,你說我怎么就攤上這事弟断。” “怎么了领舰?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵夫嗓,是天一觀的道長迟螺。 經常有香客問我,道長舍咖,這世上最難降的妖魔是什么矩父? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮排霉,結果婚禮上窍株,老公的妹妹穿的比我還像新娘。我一直安慰自己攻柠,他們只是感情好球订,可當我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著瑰钮,像睡著了一般冒滩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上浪谴,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天开睡,我揣著相機與錄音,去河邊找鬼苟耻。 笑死篇恒,一個胖子當著我的面吹牛,可吹牛的內容都是我干的凶杖。 我是一名探鬼主播胁艰,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼智蝠!你這毒婦竟也來了腾么?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤杈湾,失蹤者是張志新(化名)和其女友劉穎哮翘,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體毛秘,經...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡饭寺,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了叫挟。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片艰匙。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖抹恳,靈堂內的尸體忽然破棺而出员凝,到底是詐尸還是另有隱情,我是刑警寧澤奋献,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布健霹,位于F島的核電站旺上,受9級特大地震影響,放射性物質發(fā)生泄漏糖埋。R本人自食惡果不足惜宣吱,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望瞳别。 院中可真熱鬧征候,春花似錦、人聲如沸祟敛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽馆铁。三九已至跑揉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間埠巨,已是汗流浹背畔裕。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留乖订,地道東北人。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓具练,卻偏偏與公主長得像乍构,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子扛点,可洞房花燭夜當晚...
    茶點故事閱讀 45,691評論 2 361

推薦閱讀更多精彩內容