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的更多相关文章

  1. 在vue中使用Echarts画曲线图(异步加载数据)

    现实的工作中, 数据不可能写死的,所有的数据都应该通过发送请求进行获取. 所以本项目的需求是请求服务器获得二维数组,并生成曲线图.曲线图的横纵坐标均从获得的数据中取得. Echarts官方文档: ht ...

  2. 新手教程:不写JS,在MIP页中实现异步加载数据

    从需求谈起:在 MIP 页中异步加载数据 MIP(移动网页加速器) 的 加速原理 除了靠谱的 MIP-Cache CDN 加速外,最值得一提的就是组件系统.所有 JS 交互都需要使用 MIP 组件实现 ...

  3. HTML5中script的async属性异步加载JS

    HTML5中script的async属性异步加载JS     HTML4.01为script标签定义了5个属性: charset 可选.指定src引入代码的字符集,大多数浏览器忽略该值.defer 可 ...

  4. 淘宝购物车页面 智能搜索框Ajax异步加载数据

    如果有朋友对本篇文章的一些知识点不了解的话,可以先阅读此篇文章.在这篇文章中,我大概介绍了一下构建淘宝购物车页面需要的基础知识. 这篇文章主要探讨的是智能搜索框Ajax异步加载数据.jQuery的社区 ...

  5. winform异步加载数据到界面

    做一个学习记录. 有两个需求: 1.点击按钮,异步加载数据,不卡顿UI. 2.把获取的数据加载到gridview上面. 对于需求1,2,代码如下: public delegate void ShowD ...

  6. [Android Pro] 使用CursorLoader异步加载数据 from 3.0

    Android 3.0引入了CursorLoader实现异步加载数据,为了避免同步查询数据库时阻塞UI线程的问题.在API 11之前可以通过下载支持库,来使之前的系统支持此功能,下载页面为 http: ...

  7. android 网络异步加载数据进度条

    ProgressDialog progressDialog = null; public static final int MESSAGETYPE = 0; private void execute( ...

  8. 向上滚动或者向下滚动分页异步加载数据(Ajax + lazyload)[上拉加载组件]

    /**** desc : 分页异步获取列表数据,页面向上滚动时候加载前面页码,向下滚动时加载后面页码 ajaxdata_url ajax异步的URL 如data.php page_val_name a ...

  9. Highcharts 异步加载数据曲线图表

    导入 data.js 文件 异步加载数据需要引入以下js 文件: <script src="http://code.highcharts.com/modules/data.js&quo ...

随机推荐

  1. 【CF1217F】Forced Online Queries Problem

    题意 题目链接 动态图连通性,加密方式为 \((x+l-1)\bmod n +1\) (\(l=[上一次询问的两点连通]\)). 点数 \(n\),操作数 \(m\) \(\le 2\times 10 ...

  2. sass计算高度

    页面布局时,有时候需要两个div充满父div空间,设定一个div尺寸后,可以使用css计算高度设置另一个尺寸: <style> .wrap{ width:1000px; } .left{ ...

  3. 题解 hdu4624 Endless Spin

    题目链接 题目大意: 有长度为\(n\)的区间,每次随机选择一段(左右端点都是整数)染黑,问期望多少次全部染黑. \(n\leq 50\) 设\(n\)个随机变量\(t_1,...,t_n\).\(t ...

  4. Tornado -- 7 - 查询结果

    查询结果 查询结果总结: 条件查询 多表查询

  5. PE文件结构体-IMAGE_SECTION_HEADER

    在PE文件头与原始数据之间存在一个区块表(Section Table),它是一个IMAGE_SECTION_HEADER结构数组, 区块表包含每个块在映像中的信息(如位置.长度.属性),分别指向不同的 ...

  6. NFC性价比高频读卡器首选方案:FM17550

    FM17550具有低电压.低功耗.驱动能力强.多接口支持.多协议支持等特点.适用于低功耗.低电压.低成本要求的非接触读写器应用,及NFC协议兼容的NFC设备. FM17550是一款高度集成的工作在13 ...

  7. mysql 权限管理 grant revoke

    grant all privileges  on  database.table to 'user'@'ip' identified by 'passwd' with grant  option; g ...

  8. 用BusyBox制作Linux最小系统

    1.下载busybox-1.30.1 地址:https://busybox.net/downloads/busybox-1.30.1.tar.bz2 2.解压:tar xvf busybox-1.30 ...

  9. jenkins#自动构建并部署springboot的jar包

    1.GitLab 8.0.0(版本比较低,配置比较简单) 配置 点击项目 --> settings --> web Hooks 2.jenkins配置

  10. centos7下安装ansible

    由于centos7预装了python,因此我们可以跳过python的安装环节(记得关闭防火墙) [root@model ~]# [root@model ~]# python --version Pyt ...