dispatch_after 的延迟执行分析

dispcth_after 是将block 中的任务延迟添加到它将要执行的队列中去,而并不一定添加到队列中就立即会去执行任务。

图中表示是在5秒中后将任务添加到主队列中,如果主队列中还有另外的任务假设A、B 要执行,那么这个任务会在任务A、B 执行完后才会开始执行。


验证的代码如下:

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
        NSLog(@"我是延迟执行的函数 --- ");
    });
    
    dispatch_queue_t delayQueue = dispatch_queue_create("rx.queue.delay", nil);
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(6 * NSEC_PER_SEC)), delayQueue, ^{
        NSLog(@"我是在子线程 delayQueue 中延迟执行的函数 --- ");
    });
    
    NSLog(@"开始执行好耗时操作 --- ");
    for (int i = 0; i<1000000000; i++) {
        self.testCount ++;
    }
    NSLog(@"耗时操作执行完成 --- ");
    
    NSLog(@"第二个开始执行好耗时操作 --- ");
    for (int i = 0; i<1000000000; i++) {
        self.testCount ++;
    }
    NSLog(@"第二个耗时操作执行完成 --- ");

执行的结果如下:


可以看到,一开始进入界面就会有两个的耗时操作的任务在主线程的队列中执行以及等待执行,5秒钟后会添加一个延迟执行的任务A到主线程中,6秒钟后会添加一个延迟执行的任务B 到一个创建的子线程中。

队列中,是执行完了一个任务才会去执行下一个任务的。在主线程的队列中,任务A 是排在两个耗时操作之后添加的,所以即使任务A 是在16:28:22 添加到队列中的,它也并不会去执行,而是等到两个耗时操作都执行完了才执行。

而任务B 呢,是在16:28:23 添加等到创建的子线程中的,由于子线程的队列中并没有任务在排队,所以一添加上去就可以执行了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值