swift中利用系统线程实现异步加载数据同步更新UI
swift中的使用案例样式
// Mark: -数据源更新
typealias AddDataBlock = () ->Void
var updataBlock:AddDataBlock?
func loadLiveData(){
let grpup = DispatchGroup()
grpup.enter()
// //首页直播接口请求
HomeLiveProvider.request(.liveList) { result in
if case let .success(response) = result {
//解析数据
let data = try? response.mapJSON()
let json = JSON(data!)
if let mappedObject = JSONDeserializer<HomeLiveModel>.deserializeFrom(json: json.description) { // 从字符串转换为对象实例
self.lives = mappedObject.data?.lives
self.categoryVoList = mappedObject.data?.categoryVoList
// self.collectionView.reloadData()
// 更新tableView数据
// self.updataBlock?()
grpup.leave()
}
}
}
grpup.enter()
// //首页直播滚动图接口请求
HomeLiveProvider.request(.liveBannerList) { result in
if case let .success(response) = result {
//解析数据
let data = try? response.mapJSON()
let json = JSON(data!)
if let mappedObject = JSONDeserializer<HomeLiveBanerModel>.deserializeFrom(json: json.description) { // 从字符串转换为对象实例
self.homeLiveBanerList = mappedObject.data
// let index: IndexPath = IndexPath.init(row: 0, section: 1)
// self.collectionView.reloadItems(at: [index])
// 更新tableView数据
// self.updataBlock?()
grpup.leave()
}
}
}
grpup.enter()
// //首页直播排行榜接口请求
HomeLiveProvider.request(.liveRankList) { result in
if case let .success(response) = result {
//解析数据
let data = try? response.mapJSON()
let json = JSON(data!)
if let mappedObject = JSONDeserializer<HomeLiveRankModel>.deserializeFrom(json: json.description) { // 从字符串转换为对象实例
self.multidimensionalRankVos = mappedObject.data?.multidimensionalRankVos
// let index: IndexPath = IndexPath.init(row: 0, section: 2)
// self.collectionView.reloadItems(at: [index])
// 更新tableView数据
// self.updataBlock?()
grpup.leave()
}
}
}
grpup.notify(queue: DispatchQueue.main) {
self.updataBlock?()
}
}
oc中的使用样式
//一个并发队列
dispatch_queue_t queueE = dispatch_queue_create("group.queue", DISPATCH_QUEUE_CONCURRENT);
//一个线程组
dispatch_group_t groupE = dispatch_group_create();
////1.请求轮播图的数据
dispatch_group_async(groupE, queueE, ^{
dispatch_group_enter(groupE);
dispatch_async(dispatch_get_global_queue(0, 0), ^{
[self requestCarousel:^{
dispatch_group_leave(groupE);
}];
});
});
////2.请求新闻轮播图的数据
dispatch_group_async(groupE, queueE, ^{
dispatch_group_enter(groupE);
dispatch_async(dispatch_get_global_queue(0, 0), ^{
[self requestNews:^{
dispatch_group_leave(groupE);
}];
});
});
////3.校园活动【师生展评】
dispatch_group_async(groupE, queueE, ^{
dispatch_group_enter(groupE);
dispatch_async(dispatch_get_global_queue(0, 0), ^{
//3.校园活动【师生展评】
[self requestCampAcitivetis:^{
dispatch_group_leave(groupE);
}];
});
});
////4.尾部视图
dispatch_group_async(groupE, queueE, ^{
dispatch_group_enter(groupE);
dispatch_async(dispatch_get_global_queue(0, 0), ^{
//3.尾部视图
[self requestClass:^{
dispatch_group_leave(groupE);
}];
});
});
dispatch_group_notify(groupE, dispatch_get_main_queue(), ^{
//staticWeakSelf 随情况而定
[staticWeakSelf setUpUI];
});
//1.请求轮播图的数据
- (void)requestCarousel:(void(^)(void))leveBlock{
[AFHTTPRequestManager reqesutSuccess{
if (leveBlock) {
leveBlock();
}
} requestFaliure{
if (leveBlock) {
leveBlock();
}
}
}
swift中利用系统线程实现异步加载数据同步更新UI的更多相关文章
- 在vue中使用Echarts画曲线图(异步加载数据)
现实的工作中, 数据不可能写死的,所有的数据都应该通过发送请求进行获取. 所以本项目的需求是请求服务器获得二维数组,并生成曲线图.曲线图的横纵坐标均从获得的数据中取得. Echarts官方文档: ht ...
- 新手教程:不写JS,在MIP页中实现异步加载数据
从需求谈起:在 MIP 页中异步加载数据 MIP(移动网页加速器) 的 加速原理 除了靠谱的 MIP-Cache CDN 加速外,最值得一提的就是组件系统.所有 JS 交互都需要使用 MIP 组件实现 ...
- HTML5中script的async属性异步加载JS
HTML5中script的async属性异步加载JS HTML4.01为script标签定义了5个属性: charset 可选.指定src引入代码的字符集,大多数浏览器忽略该值.defer 可 ...
- 淘宝购物车页面 智能搜索框Ajax异步加载数据
如果有朋友对本篇文章的一些知识点不了解的话,可以先阅读此篇文章.在这篇文章中,我大概介绍了一下构建淘宝购物车页面需要的基础知识. 这篇文章主要探讨的是智能搜索框Ajax异步加载数据.jQuery的社区 ...
- winform异步加载数据到界面
做一个学习记录. 有两个需求: 1.点击按钮,异步加载数据,不卡顿UI. 2.把获取的数据加载到gridview上面. 对于需求1,2,代码如下: public delegate void ShowD ...
- [Android Pro] 使用CursorLoader异步加载数据 from 3.0
Android 3.0引入了CursorLoader实现异步加载数据,为了避免同步查询数据库时阻塞UI线程的问题.在API 11之前可以通过下载支持库,来使之前的系统支持此功能,下载页面为 http: ...
- android 网络异步加载数据进度条
ProgressDialog progressDialog = null; public static final int MESSAGETYPE = 0; private void execute( ...
- 向上滚动或者向下滚动分页异步加载数据(Ajax + lazyload)[上拉加载组件]
/**** desc : 分页异步获取列表数据,页面向上滚动时候加载前面页码,向下滚动时加载后面页码 ajaxdata_url ajax异步的URL 如data.php page_val_name a ...
- Highcharts 异步加载数据曲线图表
导入 data.js 文件 异步加载数据需要引入以下js 文件: <script src="http://code.highcharts.com/modules/data.js&quo ...
随机推荐
- LR_问题_平均响应时间解释,summary与analysis不一致----Summary Report中的时间说明
Summary是按整个场景的时间来做平均的,最大最小值,也是从整个场景中取出来的. (1) 平均响应时间:事物全部响应时间做平均计算 (2) 90%响应时间:将事物全部响应时间 ...
- esxi命令行强行关闭虚拟机
目的:强行关闭通过前端界面无法关闭的ESXI虚拟机 环境:esxi5.1-esxi6.5 背景:如果esxi下面某一台vm死机了,并且esxi的控制台卡死不能用,为了不影响同一个esx下其他的vm正常 ...
- CVE-2019-0708 漏洞分析及相关测试
在CVE-2019-0708公布后几天就已经尝试过复现该漏洞,但借助当时exp并没能成功复现反弹shell的过程遂放弃,故借助这次漏洞复现报告再来尝试复现该漏洞,因为还在大三学习中,有很多知识还没有掌 ...
- Ubuntu 更新源 内核升级
cat /etc/apt/sources.listdeb http://mirrors.sohu.com/ubuntu/ precise main restricted universe multiv ...
- spark aggregate算子
spark aggregate源代码 /** * Aggregate the elements of each partition, and then the results for all the ...
- ACM-寻宝
题目描述:寻宝 有这么一块神奇的矩形土地,为什么神奇呢?因为上面藏有很多的宝藏.该土地由N*M个小正方形土地格子组成,每个小正方形土地格子上,如果标有“E”,则表示该格可以通过:如果标有“X”,则表示 ...
- POJ 3916:Duplicate Removal 将相近的重复元素删除
Duplicate Removal Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1745 Accepted: 1213 ...
- (win32)解决虚拟按键被输入法截获(转)
源博客地址:http://blog.csdn.net/kencaber/article/details/51417871 响应WM_KEYDOWN消息时发现`~快捷键无效,设置断点发现得到的按键消息根 ...
- 如何禁用AD OU 下面的邮箱用户的Exchange ActiveSync 和 适用于设备的OWA
Get-Mailbox -OrganizationalUnit QQ禁用名单 | Set-CASMailbox -ActiveSyncEnabled $false -OWAforDevicesEna ...
- Git TortoiseGit github 操作
由于公司采用了分布式架构,选择的是gitlab git 来管理代码等工作,鉴于github和gitlab的相似性,网上查看好多都是用git的命令上传,或者是一部分,为此,借鉴多方网络,并进行实际操作, ...