dispatch_group_enter 、 dispatch_group_leave

dispatch_group_enter和dispatch_group_leave必须成对出现 ,来给group添加新任务。

dispatch_group_enter(group)
//执行的事件
dispatch_group_leave(group)

为什么会用到这个方法呢?
因为在dispatch_group_async()里使用dispatch_async()方法,dispatch_group_notify不是在最后执行的。而dispatch_sync()方法调用的时候正常。代码如下:

一、使用dispatch_group_async()方法
1、异步里异步并发

    dispatch_queue_t queue = dispatch_queue_create("dispatchGroupMethod1.queue", DISPATCH_QUEUE_CONCURRENT);
    dispatch_group_t group = dispatch_group_create();
    
    dispatch_group_async(group, queue, ^{
        dispatch_async(queue, ^{
            for (NSInteger i =0; i<3; i++) {
                sleep(1);
                NSLog(@"任务1-异步任务执行-:%ld,thread:%@",(long)i,[NSThread currentThread]);
            }
        });
    });
    
    dispatch_group_async(group, queue, ^{
        dispatch_async(queue, ^{
            for (NSInteger i =0; i<3; i++) {
                sleep(1);
                NSLog(@"任务2-异步任务执行-:%ld,thread:%@",(long)i,[NSThread currentThread]);
            }
        });
    });
    
    //等待上面的任务全部完成后,会收到通知执行block中的代码 (不会阻塞线程)
    dispatch_group_notify(group, queue, ^{
        NSLog(@"全部任务执行完成");
    });
//打印如下
2018-03-09 16:54:37.009913+0800 ceshi[3934:349413] 全部任务执行完成
2018-03-09 16:54:38.014204+0800 ceshi[3934:349411] 任务1-异步任务执行-:0,thread:<NSThread: 0x60000026cb00>{number = 3, name = (null)}
2018-03-09 16:54:38.014204+0800 ceshi[3934:349414] 任务2-异步任务执行-:0,thread:<NSThread: 0x6040004799c0>{number = 4, name = (null)}
2018-03-09 16:54:39.018626+0800 ceshi[3934:349414] 任务2-异步任务执行-:1,thread:<NSThread: 0x6040004799c0>{number = 4, name = (null)}
2018-03-09 16:54:39.018626+0800 ceshi[3934:349411] 任务1-异步任务执行-:1,thread:<NSThread: 0x60000026cb00>{number = 3, name = (null)}
2018-03-09 16:54:40.020653+0800 ceshi[3934:349411] 任务1-异步任务执行-:2,thread:<NSThread: 0x60000026cb00>{number = 3, name = (null)}
2018-03-09 16:54:40.020653+0800 ceshi[3934:349414] 任务2-异步任务执行-:2,thread:<NSThread: 0x6040004799c0>{number = 4, name = (null)}

异步并发,dispatch_group_notify先执行,没在最后调用。

2、异步里同步并发:

    dispatch_queue_t queue = dispatch_queue_create("dispatchGroupMethod1.queue", DISPATCH_QUEUE_CONCURRENT);
    dispatch_group_t group = dispatch_group_create();
    dispatch_group_async(group, queue, ^{
        dispatch_sync(queue, ^{
            for (NSInteger i =0; i<3; i++) {
                sleep(1);
                NSLog(@"任务1-同步任务执行-:%ld,thread:%@",(long)i,[NSThread currentThread]);
            }
        });
    });
    
    dispatch_group_async(group, queue, ^{
        dispatch_sync(queue, ^{
            for (NSInteger i =0; i<3; i++) {
                sleep(1);
                NSLog(@"任务2-同步任务执行-:%ld,thread:%@",(long)i,[NSThread currentThread]);
            }
        });
    });
    
    //等待上面的任务全部完成后,会收到通知执行block中的代码 (不会阻塞线程)
    dispatch_group_notify(group, queue, ^{
        NSLog(@"全部任务执行完成");
    });
//打印如下
2018-03-09 16:56:42.372297+0800 ceshi[3985:353717] 任务2-同步任务执行-:0,thread:<NSThread: 0x604000273e40>{number = 4, name = (null)}
2018-03-09 16:56:42.372297+0800 ceshi[3985:353715] 任务1-同步任务执行-:0,thread:<NSThread: 0x604000273e00>{number = 3, name = (null)}
2018-03-09 16:56:43.374677+0800 ceshi[3985:353717] 任务2-同步任务执行-:1,thread:<NSThread: 0x604000273e40>{number = 4, name = (null)}
2018-03-09 16:56:43.374677+0800 ceshi[3985:353715] 任务1-同步任务执行-:1,thread:<NSThread: 0x604000273e00>{number = 3, name = (null)}
2018-03-09 16:56:44.380101+0800 ceshi[3985:353715] 任务1-同步任务执行-:2,thread:<NSThread: 0x604000273e00>{number = 3, name = (null)}
2018-03-09 16:56:44.380101+0800 ceshi[3985:353717] 任务2-同步任务执行-:2,thread:<NSThread: 0x604000273e40>{number = 4, name = (null)}
2018-03-09 16:56:44.380617+0800 ceshi[3985:353717] 全部任务执行完成

二、使用dispatch_group_enter和dispatch_group_leave

1、异步执行

//异步
dispatch_queue_t queue = dispatch_queue_create("dispatchGroupMethod1.queue", DISPATCH_QUEUE_CONCURRENT);
    dispatch_group_t group = dispatch_group_create();
    
    dispatch_async(queue, ^{
        dispatch_group_enter(group);
        for (NSInteger i =0; i<3; i++) {
            sleep(1);
            NSLog(@"任务1-异步任务执行-:%ld,thread:%@",(long)i,[NSThread currentThread]);
        }
        dispatch_group_leave(group);
    });
    
    dispatch_async(queue, ^{
        dispatch_group_enter(group);
        for (NSInteger i =0; i<3; i++) {
            sleep(1);
            NSLog(@"任务2-异步任务执行-:%ld,thread:%@",(long)i,[NSThread currentThread]);
        }
        dispatch_group_leave(group);
    });
    //等待上面的任务全部完成后,会收到通知执行block中的代码 (不会阻塞线程)
    dispatch_group_notify(group, queue, ^{
        NSLog(@"全部任务执行完成");
    });
//结果
2018-03-09 17:28:47.644739+0800 ceshi[4322:392667] 任务2-异步任务执行-:0,thread:<NSThread: 0x600000266b00>{number = 4, name = (null)}
2018-03-09 17:28:47.644739+0800 ceshi[4322:392666] 任务1-异步任务执行-:0,thread:<NSThread: 0x60400027dbc0>{number = 3, name = (null)}
2018-03-09 17:28:48.646245+0800 ceshi[4322:392667] 任务2-异步任务执行-:1,thread:<NSThread: 0x600000266b00>{number = 4, name = (null)}
2018-03-09 17:28:48.646245+0800 ceshi[4322:392666] 任务1-异步任务执行-:1,thread:<NSThread: 0x60400027dbc0>{number = 3, name = (null)}
2018-03-09 17:28:49.650996+0800 ceshi[4322:392667] 任务2-异步任务执行-:2,thread:<NSThread: 0x600000266b00>{number = 4, name = (null)}
2018-03-09 17:28:49.650996+0800 ceshi[4322:392666] 任务1-异步任务执行-:2,thread:<NSThread: 0x60400027dbc0>{number = 3, name = (null)}
2018-03-09 17:28:49.651347+0800 ceshi[4322:392666] 全部任务执行完成

2、同步执行

//同步
 dispatch_queue_t queue = dispatch_queue_create("dispatchGroupMethod1.queue", DISPATCH_QUEUE_CONCURRENT);
    dispatch_group_t group = dispatch_group_create();
    
    dispatch_sync(queue, ^{
        dispatch_group_enter(group);
        for (NSInteger i =0; i<3; i++) {
            sleep(1);
            NSLog(@"任务1-同步任务执行-:%ld,thread:%@",(long)i,[NSThread currentThread]);
        }
        dispatch_group_leave(group);
    });
    
    dispatch_sync(queue, ^{
        dispatch_group_enter(group);
        for (NSInteger i =0; i<3; i++) {
            sleep(1);
            NSLog(@"任务2-同步任务执行-:%ld,thread:%@",(long)i,[NSThread currentThread]);
        }
        dispatch_group_leave(group);
    });
    //等待上面的任务全部完成后,会收到通知执行block中的代码 (不会阻塞线程)
    dispatch_group_notify(group, queue, ^{
        NSLog(@"全部任务执行完成");
    });

//结果
2018-03-09 17:42:34.271283+0800 ceshi[4454:413740] 任务1-同步任务执行-:0,thread:<NSThread: 0x600000068980>{number = 1, name = main}
2018-03-09 17:42:35.272241+0800 ceshi[4454:413740] 任务1-同步任务执行-:1,thread:<NSThread: 0x600000068980>{number = 1, name = main}
2018-03-09 17:42:36.273663+0800 ceshi[4454:413740] 任务1-同步任务执行-:2,thread:<NSThread: 0x600000068980>{number = 1, name = main}
2018-03-09 17:42:37.275635+0800 ceshi[4454:413740] 任务2-同步任务执行-:0,thread:<NSThread: 0x600000068980>{number = 1, name = main}
2018-03-09 17:42:38.276095+0800 ceshi[4454:413740] 任务2-同步任务执行-:1,thread:<NSThread: 0x600000068980>{number = 1, name = main}
2018-03-09 17:42:39.277732+0800 ceshi[4454:413740] 任务2-同步任务执行-:2,thread:<NSThread: 0x600000068980>{number = 1, name = main}
2018-03-09 17:42:39.278429+0800 ceshi[4454:413852] 全部任务执行完成

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • 本文首发于我的个人博客:「程序员充电站」[https://itcharge.cn]文章链接:「传送门」[https...
    ITCharge阅读 344,825评论 308 1,921
  • 背景 担心了两周的我终于轮到去医院做胃镜检查了!去的时候我都想好了最坏的可能(胃癌),之前在网上查的症状都很相似。...
    Dely阅读 9,178评论 21 42
  • 同步/异步 同步:多个任务情况下,一个任务A执行结束,才可以执行另一个任务B。只存在一个线程也就是主线程。 异步:...
    XLsn0w阅读 281评论 0 0
  • 减肥的受众人群是庞大的。 在很多人心中,肥胖这种因对自身放任而导致的后果被视为了疾病!疾病就需要治疗,于是大街上随...
    罗随缘阅读 1,881评论 10 43
  • <head> 或 <body> 中的 JavaScript 您可以在 HTML 文档中放入不限数量的脚本。脚本可位...
    海娩阅读 176评论 0 0