IOS深入理解GCD之dispatch_sync

void dispatch_sync( dispatch_queue_t queue, dispatch_block_t block);

  dispatch_sync_的定义如上所示,将block添加到queue中,不管queue是并行队列还是串行队列,block的执行满足FIFO需要等待先进入queue中的block执行完之后才能被执行,在同一个queue中同一时刻只能有一个block执行。

//创建一个并行队列
    dispatch_queue_t queue2 = dispatch_queue_create("concurrent.dispatch.queue", DISPATCH_QUEUE_CONCURRENT);
    dispatch_sync(queue2, ^{
        NSLog(@"step0");
    });
    
    //创建一个串行队列
    dispatch_queue_t queue1 = dispatch_queue_create("serial.dispatch.queue", DISPATCH_QUEUE_SERIAL);
    dispatch_sync(queue1, ^{
        NSLog(@"step1");
    });
    dispatch_sync(queue1, ^{
        NSLog(@"step2");
    });

  程序的输出结果:

step0
step1
step2

  如果queue是一个并行队列,理论上并行队列中的block应该并行,但是通过实验验证,queue中的block是串行执行的,为什么?难道是我理解错了

dispatch_queue_t concurrentQueue = dispatch_queue_create("concurrent.dispatch.queue", DISPATCH_QUEUE_CONCURRENT);
    dispatch_sync(concurrentQueue, ^{
        NSLog(@"step1");
    });
    dispatch_sync(concurrentQueue, ^{
        NSLog(@"step2");
    });

  程序输出结果:

step1
step2

  由此可以得出结论,对于并发队列而言,如果作为参数传入到dispatchsync中,那queue中的block是串行执行的,根据深入理解dispatchsync中的描述,在调用dispatchsync时,在底层是对queue进行了加锁,在一个block执行完之后才能取其他的block来执行。这样就不能够发挥出并行队列的并发执行的价值。

写这篇博客时还是有一个没有理解到的问题,既然dispatchsync是串行执行,并且要阻塞当前线程,那么直接在当前线程中执行block的代码就可以了,那么dispatchsync就没有存在的意义了,这点没有想明白,why?

 

  参考资料:

http://zhangbuhuai.com/2015/04/11/%E6%B7%B1%E5%85%A5%E7%90%86%E8%A7%A3dispatch_sync/

 

posted @ 2016-05-04 10:16  pstune  阅读(1510)  评论(0编辑  收藏  举报