加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

完整详解swift GCD系列(三)dispatch_group

发布时间:2020-12-14 06:34:13 所属栏目:百科 来源:网络整理
导读:原创Blog,转载请注明出处 http://blog.csdn.net/column/details/swift-gcd.html 一、dispatch_group 把一组任务提交到队列中,这些队列可以不相关,然后坚挺这组任务完成的事件。 几个用到的函数 1、dispatch_group_create创建一个调度任务组 [plain] view
原创Blog,转载请注明出处
http://blog.csdn.net/column/details/swift-gcd.html
一、dispatch_group
把一组任务提交到队列中,这些队列可以不相关,然后坚挺这组任务完成的事件。
几个用到的函数
1、dispatch_group_create创建一个调度任务组
[plain] view plain copy
  1. funcdispatch_group_create()->dispatch_group_t!

2、dispatch_group_async 把一个任务异步提交到任务组里
copy
    funcdispatch_group_async(_group:dispatch_group_t!,
  1. _queue:dispatch_queue_t!,
  2. _block:dispatch_block_t!)

参数: group 提交到的任务组,这个任务组的对象会一直持续到任务组执行完毕
queue 提交到的队列,任务组里不同任务的队列可以不同
block 提交的任务

3、dispatch_group_enter/dispatch_group_leave
copy
    funcdispatch_group_enter(_group:dispatch_group_t!)
  1. funcdispatch_group_leave(_group:dispatch_group_t!)
这两个方法显示的讲任务组中的任务未执行完毕的任务数目加减1,这种方式用在不使用dispatch_group_async来提交任务,注意:这两个函数要配合使用,有enter要有leave,这样才能保证功能完整实现。也可以用这对函数来让一个闭包关联多个Group
4、dispatch_group_notify 用来监听任务组事件的执行完毕
copy
    funcdispatch_group_notify(_group:dispatch_group_t!,108); list-style:decimal-leading-zero outside; color:inherit; line-height:18px; margin:0px!important; padding:0px 3px 0px 10px!important"> _block:dispatch_block_t!)
监听的任务组
queue 执行完毕的这个闭包所在的队列
block 执行完毕所响应的任务
5、dispatch_group_wait 设置等待时间,在等待时间结束后,如果还没有执行完任务组,则返回。返回0代表执行成功,非0则执行失败
copy
    longdispatch_group_wait(dispatch_group_tgroup,dispatch_time_ttimeout);

二、完整的代码解析,模拟提交三个下载任务
copy
    classViewController:UIViewController{
  1. overridefuncviewDidLoad(){
  2. super.viewDidLoad()
  3. varhwcGroup=dispatch_group_create()//创建group
  4. varglobalQueueDefault=dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0)//全局队列,这个队列为并行队列
  5. varuserCreateQueue=dispatch_queue_create("com.test.helloHwc",DISPATCH_QUEUE_SERIAL)//创建一个用户队列,这个队列为串行队列
  6. downLoadTask1(group:hwcGroup,queue:globalQueueDefault)
  7. downLoadTask2(group:hwcGroup,queue:userCreateQueue)
  8. downLoadTask3(group:hwcGroup,queue:userCreateQueue)
  9. //letresult=dispatch_group_wait(hwcGroup,DISPATCH_TIME_FOREVER)
  10. dispatch_group_notify(hwcGroup,dispatch_get_main_queue()){
  11. NSLog("Grouptasksaredone")
  12. }
  13. println("NowviewDidLoadisdone")
  14. funcdownLoadTask1(#group:dispatch_group_t,queue:dispatch_queue_t){
  15. dispatch_group_async(group,queue){
  16. sleep(3)
  17. NSLog("Task1isdone")
  18. }
  19. funcdownLoadTask2(#group:dispatch_group_t,108); list-style:decimal-leading-zero outside; color:inherit; line-height:18px; margin:0px!important; padding:0px 3px 0px 10px!important"> NSLog("Task2isdone")
  20. funcdownLoadTask3(#group:dispatch_group_t,108); list-style:decimal-leading-zero outside; color:inherit; line-height:18px; margin:0px!important; padding:0px 3px 0px 10px!important"> NSLog("Task3isdone")
  21. overridefuncdidReceiveMemoryWarning(){
  22. super.didReceiveMemoryWarning()
  23. }

可以看到输出为

copy
    NowviewDidLoadisdone
  1. Task2isdone
  2. Task1isdone
  3. Task3isdone
  4. Grouptaskisdone

这里task1提交到全局队列中,task2和task3提交到用户穿件的串行队列中,所以task1和task2同时输出,task3在task2结束两秒后输出。

如果把注释那行取消,会等待一段时间,再返回,读者可以自己去试验下

三、关于如何使用dispatch_group_enter/dispatch_group_leave如何使用

copy
    <prename="code"class="plain">classViewController:UIViewController{
  1. forindex:UInt32in1...3{
  2. dispatch_group_enter(hwcGroup)//提交了一个任务,任务数目加1
  3. manualDownLoad(index){
  4. println("Task(index)isdone")
  5. dispatch_group_leave(hwcGroup)//完成一个任务,任务数目减1
  6. letresult=dispatch_group_wait(hwcGroup,DISPATCH_TIME_FOREVER)//等待直到完成
  7. dispatch_group_notify(hwcGroup,dispatch_get_main_queue()){
  8. println("Grouptasksaredone")
  9. println("NowviewDidLoadisdone")
  10. funcmanualDownLoad(num:UInt32,block:()->()){
  11. println("Downloadingtask(num)")
  12. sleep(num)
  13. block()
  14.  
    

    输出

    copy

      Downloadingtask1
    1. Task1isdone
    2. Downloadingtask2
    3. Downloadingtask3
    4. NowviewDidLoadisdone
    5. Groupisdone

    可以看到,同步进行了下载,这里的任务是串行的,实际消耗时间9s。当然,也可以把下载的任务提交到异步队列中

    copy

      manualDownLoad(index,queue:globalQueueDefault){
    1. NSLog("Task(index)isdone")
    2. NSLog("NowviewDidLoadisdone")
    3. funcmanualDownLoad(num:UInt32,queue:dispatch_queue_t,block:()->()){
    4. dispatch_async(queue){
    5. NSLog("Downloadingtask(num)")
    6. overridefuncdidReceiveMemoryWarning(){
    7. super.didReceiveMemoryWarning()
    8. }

    这样的话,输出是

    copy

      Downloadingtask2
    1. NowviewDidLoadisdone
    2. Task3isdone

    由于三个模拟的下载任务是并行的,所以实际消耗时间3s

    (编辑:李大同)

    【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读