• dispatch_async 和dispatch_sync


    dispatch_sync(),同步添加操作。他是等待添加进队列里面的操作完成之后再继续执行。

    复制代码
        dispatch_queue_t concurrentQueue = dispatch_queue_create("my.concurrent.queue", DISPATCH_QUEUE_CONCURRENT);
        NSLog(@"1");
        dispatch_sync(concurrentQueue, ^(){
            NSLog(@"2");
            [NSThread sleepForTimeInterval:10];
            NSLog(@"3");
        });
        NSLog(@"4");
    输出 :

    11:36:25.313 GCDSeTest[544:303] 1

    11:36:25.313 GCDSeTest[544:303] 2

    11:36:30.313 GCDSeTest[544:303] 3//模拟长时间操作

    11:36:30.314 GCDSeTest[544:303] 4

    复制代码

    dispatch_async ,异步添加进任务队列,它不会做任何等待

    复制代码
        dispatch_queue_t concurrentQueue = dispatch_queue_create("my.concurrent.queue", DISPATCH_QUEUE_CONCURRENT);
        NSLog(@"1");
        dispatch_async(concurrentQueue, ^(){
            NSLog(@"2");
            [NSThread sleepForTimeInterval:5];
            NSLog(@"3");
        });
        NSLog(@"4");
    输出:

     11:42:43.820 GCDSeTest[568:303] 1

     11:42:43.820 GCDSeTest[568:303] 4

     11:42:43.820 GCDSeTest[568:1003] 2

     11:42:48.821 GCDSeTest[568:1003] 3//模拟长时间操作时间

    有a、b、c、d 4个异步请求,如何判断a、b、c、d都完成执行?如果需要a、b、c、d顺序执行,该如何实现?

    参考答案:

    1. 对于这四个异步请求,要判断都执行完成最简单的方式就是通过GCD的group来实现:
  • 相关阅读:
    指令级并行:动态调度技术
    单纯形法的矩阵描述
    QTextEdit回车事件重写
    整数规划
    全退
    流水线分析例题
    操作系统期中复习思考题
    流水线技术概述
    中心极限定理
    大数定律
  • 原文地址:https://www.cnblogs.com/jyking/p/5200234.html
Copyright © 2020-2023  润新知