一個頁面需要同時發送網絡請求A和B 然后需要在AB都返回結果之后在進行操作 寫了個demo模擬下這種情況
第一種方法dispatch_group_t
控制
dispatch_group_t group = dispatch_group_create();
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
NSLog(@"網絡請求1和網絡請求2同時發送!");
dispatch_group_enter(group);
dispatch_async(queue, ^{
[NSThread sleepForTimeInterval:1];
NSLog(@"網絡請求1完成");
dispatch_group_leave(group);
});
dispatch_group_enter(group);
dispatch_async(queue, ^{
[NSThread sleepForTimeInterval:2];
NSLog(@"網絡請求2完成");
dispatch_group_leave(group);
});
dispatch_group_notify(group, queue, ^{
NSLog(@"網絡請求1和網絡請求2都完成!");
});
這里dispatch_group_enter
和dispatch_group_leave
一定要成對出現 然后用dispatch_group_notify
等待完成
方法二 信號量dispatch_semaphore_t
控制
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
NSLog(@"0");
dispatch_semaphore_t sem = dispatch_semaphore_create(0);
dispatch_async(queue, ^{
[NSThread sleepForTimeInterval:1];
NSLog(@"1");
dispatch_semaphore_signal(sem);
});
dispatch_async(queue, ^{
[NSThread sleepForTimeInterval:2];
NSLog(@"2");
dispatch_semaphore_signal(sem);
});
dispatch_semaphore_wait(sem, DISPATCH_TIME_FOREVER);
dispatch_semaphore_wait(sem, DISPATCH_TIME_FOREVER);
NSLog(@"都完成了");
信號量沒什么好說的 參考文章http://www.lxweimin.com/p/8fb33b89b5a7
第三種 柵欄塊dispatch_barrier_async
控制
dispatch_queue_t conQueue = dispatch_queue_create("myQueue", DISPATCH_QUEUE_CONCURRENT);
dispatch_async(conQueue, ^{
[NSThread sleepForTimeInterval:1];
NSLog(@"111");
});
dispatch_async(conQueue, ^{
[NSThread sleepForTimeInterval:2];
NSLog(@"222");
});
dispatch_barrier_async(conQueue, ^{
NSLog(@"333");
});
這里需要注意 要想執行完前面所有的任務再執行barrier必須滿足兩個條件
1、所有任務都是在同一個隊列中
2、隊列不能是全局并行隊列, 必須是自己創建的隊列
柵欄.png
這只是用GCD的三種簡單實現 當然還有其他很多方法