当前位置: 移动技术网 > IT编程>移动开发>IOS > IOS多线程实现多图片下载(一)

IOS多线程实现多图片下载(一)

2019年07月24日  | 移动技术网IT编程  | 我要评论

海丰县新闻,中国民生在线,风情万种野玫瑰快播

在没有步入正文之前先给大家展示下效果图,如果大家觉得很满意请继续往下阅读全文。

大家可以看到这个界面很简单,其实就是uitableview的布局,但是难点是在于如何从网上下载这些图片,下载之后应如何进行存储!

我们一步一步进行解析,先从单线程(主线程)进行多图片下载我们布局上的文字及图片的地址从plist文件中进行读取

根据结构,我们自定义一个数据模型文件

ddzapp.h

#import <foundation/foundation.h>
@interface ddzapp : nsobject
//图标
@property (nonatomic,strong) nsstring *icon;
//名字
@property (nonatomic,strong) nsstring *name;
//下载量
@property (nonatomic,strong) nsstring *download;
+ (instancetype)appwithdict:(nsdictionary *)dict;
@end 

ddzapp.m

#import "ddzapp.h"
@implementation ddzapp
+ (instancetype)appwithdict:(nsdictionary *)dict {
ddzapp *app = [[self alloc] init];
[app setvaluesforkeyswithdictionary:dict];
return app;
}
@end 

以下的都是视图控制器中的代码

viewcontroller.m

1.

@interface viewcontroller ()
//所有数据
@property (nonatomic,strong)nsarray *apps;
//内存缓存图片
@property (nonatomic,strong)nsmutabledictionary *imgcache;
@end 

第一个属性用于存储读取plist文件中的内容,设置为属性保存起来,就可以不用重复读取

第二个属性用于保存从网上下载下来的图片,也是为了不用重复读取

2.

@implementation viewcontroller
//读取数据
- (nsarray *)apps {
if (!_apps) {
//从plist文件中读取数据
nsarray *dictarray = [nsarray arraywithcontentsoffile:[[nsbundle mainbundle] pathforresource:@"apps.plist" oftype:nil]];
nsmutablearray *apparray = [nsmutablearray array];
for (nsdictionary *dict in dictarray) {
[apparray addobject:[ddzapp appwithdict:dict]];
}
_apps = apparray;
}
return _apps;
}
//缓存图片
- (nsmutabledictionary *)imgcache {
if (!_imgcache) {
//初始化
_imgcache = [nsmutabledictionary dictionary];
}
return _imgcache;
}

这两个方法都是为了初始化刚才的两个属性

3.

#pragma mark - 数据源方法
- (nsinteger)tableview:(uitableview *)tableview numberofrowsinsection:(nsinteger)section {
return self.apps.count;
}
- (uitableviewcell *)tableview:(uitableview *)tableview cellforrowatindexpath:(nsindexpath *)indexpath {
static nsstring *id = @"app";
uitableviewcell *cell = [tableview dequeuereusablecellwithidentifier:id];
ddzapp *app = self.apps[indexpath.row];
cell.textlabel.text = app.name;
cell.detailtextlabel.text = app.download;
//先从内存中取出图片
uiimage *image = self.imgcache[app.icon];
if (image) {
cell.imageview.image = image;
}else {
//内存中没有图片
//将图片文件数据写入到沙盒中
nsstring *cachespath = [nssearchpathfordirectoriesindomains(nscachesdirectory, nsuserdomainmask, yes) firstobject];
//获得文件名
nsstring *filename = [app.icon lastpathcomponent];
//计算出文件的全路径
nsstring *file = [cachespath stringbyappendingpathcomponent:filename];
//加载沙盒的文件数据
nsdata *data = [nsdata datawithcontentsoffile:file];
//判断沙盒中是否有图片
if (data) {
//直接加载沙盒中图片
cell.imageview.image = [uiimage imagewithdata:data];
//存到字典(内存)中
self.imgcache[app.icon] = cell.imageview.image;
}else {
//下载图片
data = [nsdata datawithcontentsofurl:[nsurl urlwithstring:app.icon]];
cell.imageview.image = [uiimage imagewithdata:data];
//存到内存中
self.imgcache[app.icon] = cell.imageview.image;
//将图片数据写入到沙盒中
[data writetofile:file atomically:yes];
}
}
return cell;
}

这两个方法是uitableview必须要实现的方法

第一个是返回数据量,没什么好说的

第二个是绑定数据

具体的流程看下图

以上内容针对ios多线程实现多图片下载(一)的相关介绍,希望对大家有所帮助,下篇文章继续给大家介绍ios多线程实现多图片下载(二),感兴趣的朋友请持续关注。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

  • ios uicollectionview实现横向滚动

    现在使用卡片效果的app很多,之前公司让实现一种卡片效果,就写了一篇关于实现卡片的文章。文章最后附有demo实现上我选择了使用uicollectionview ... [阅读全文]
  • iOS UICollectionView实现横向滑动

    本文实例为大家分享了ios uicollectionview实现横向滑动的具体代码,供大家参考,具体内容如下uicollectionview的横向滚动,目前我使... [阅读全文]
  • iOS13适配深色模式(Dark Mode)的实现

    iOS13适配深色模式(Dark Mode)的实现

    好像大概也许是一年前, mac os系统发布了深色模式外观, 看着挺刺激, 时至今日用着也还挺爽的终于, 随着iphone11等新手机的发售, ios 13系统... [阅读全文]
  • ios 使用xcode11 新建项目工程的步骤详解

    ios 使用xcode11 新建项目工程的步骤详解

    xcode11新建项目工程,新增了scenedelegate这个类,转而将原appdelegate负责的对ui生命周期的处理担子接了过来。故此可以理解为:ios... [阅读全文]
  • iOS实现转盘效果

    本文实例为大家分享了ios实现转盘效果的具体代码,供大家参考,具体内容如下demo下载地址: ios转盘效果功能:实现了常用的ios转盘效果,轮盘抽奖效果的实现... [阅读全文]
  • iOS开发实现转盘功能

    本文实例为大家分享了ios实现转盘功能的具体代码,供大家参考,具体内容如下今天给同学们讲解一下一个转盘选号的功能,直接上代码直接看viewcontroller#... [阅读全文]
  • iOS实现轮盘动态效果

    本文实例为大家分享了ios实现轮盘动态效果的具体代码,供大家参考,具体内容如下一个常用的绘图,主要用来打分之类的动画,效果如下。主要是ios的绘图和动画,本来想... [阅读全文]
  • iOS实现九宫格连线手势解锁

    本文实例为大家分享了ios实现九宫格连线手势解锁的具体代码,供大家参考,具体内容如下demo下载地址:效果图:核心代码://// clockview.m// 手... [阅读全文]
  • iOS实现卡片堆叠效果

    本文实例为大家分享了ios实现卡片堆叠效果的具体代码,供大家参考,具体内容如下如图,这就是最终效果。去年安卓5.0发布的时候,当我看到安卓全新的material... [阅读全文]
  • iOS利用余弦函数实现卡片浏览工具

    iOS利用余弦函数实现卡片浏览工具

    本文实例为大家分享了ios利用余弦函数实现卡片浏览工具的具体代码,供大家参考,具体内容如下一、实现效果通过拖拽屏幕实现卡片移动,左右两侧的卡片随着拖动变小,中间... [阅读全文]
验证码:
移动技术网