Swift-多接口请求数据

多个请求接口不分顺序执行,都执行完毕之后,再刷新界面:

1、队列组+信号量

gcd的信号量主要有3个函数,分别为
let semaphore = DispatchSemaphore(value: M)
创建一个值为M的信号量
semaphore.wait()
如果该信号量的值大于0,则使其信号量的值-1,
否则,阻塞线程直到该信号量的值大于0。
semaphore.signal()
释放信号量,使得该信号量的值加1

// 信号量: 使用信号量来阻塞住发请求的线程
private let semaphore = DispatchSemaphore(value: 0)
let group = DispatchGroup()

DispatchQueue.global().async(group: group, execute: {[weak self] in
       // 请求1
       xx网络请求1 {[weak self] (xxxx) in
            // do sth
            self?.semaphore.signal()
       }
       self?.semaphore.wait()
 })
        
DispatchQueue.global().async(group: group, execute: {[weak self] in
        // 请求2
        xx网络请求2 {[weak self] (xxxx) in
             // do sth
             self?.semaphore.signal()
        }
        self?.semaphore.wait()
 })
 group.notify(queue: DispatchQueue.main) {[weak self] in
     // UI refresh
 }
2、只队列组(1)

注意:单纯用DispatchQueue.global().async(group: group, execute: {[weak self] in xxx })(不加enter和leave, 不加信号量)实现这种顺序,前提是闭包里执行的代码得是同步任务才可以(网络请求异步不可以)。

private let group = DispatchGroup()

DispatchQueue.global().async(group: group, execute: {[weak self] in
       // 请求1
       //通知 group,下个任务要放入 group 中执行
      self?.group.enter() 
       xx网络请求1 {[weak self] (xxxx) in
            // do sth
            // 通知 group,任务成功完成,要移除,与 enter成对出现
           self?.group.leave()
       }
 })
        
DispatchQueue.global().async(group: group, execute: {[weak self] in
        // 请求2
       self?.group.enter()
        xx网络请求2 {[weak self] (xxxx) in
             // do sth
             self?.group.leave()
        }
 })

 group.notify(queue: DispatchQueue.main) {[weak self] in
     // UI refresh
 }
或者: 只队列组(2)
private let group = DispatchGroup()

  self.group.enter()
  DispatchQueue.global().async {[weak self] in
       xx网络请求1 {[weak self] (xxxx) in
            // do sth
            // 通知 group,任务成功完成,要移除,与 enter成对出现
           self?.group.leave()
       }
  }
        
  self.group.enter()
  DispatchQueue.global().async {[weak self] in
        xx网络请求2 {[weak self] (xxxx) in
             // do sth
             self?.group.leave()
        }
  }
 group.notify(queue: DispatchQueue.main) {[weak self] in
     // UI refresh
 }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Swift006-多线程 相关概念 进程指在系统中正在运行的一个应用程序,进程拥有独立运行所需的全部资源(例如:正...
    DDY阅读 778评论 0 2
  • 1,Swift继续使用Object-C原有的一套线程,包括三种多线程编程技术: (1)Thread (2)Coco...
    yunxiu阅读 970评论 0 1
  • swift 3中对C层级的GCD的API进行了彻头彻尾的改变。本文将从实际使用场景来了解一下新的api使用。 di...
    飘金阅读 452评论 0 1
  • 引言 今天从Books中翻出了“沉淀”已久的关于并发编程书,读完之后,感受颇多,有一些不确定的知识点更加清晰了。在...
    SimonMont阅读 1,714评论 0 4
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 8,619评论 28 53