解决网络请求的依赖关系
怎么解决网络请求的依赖关系:当一个接口的请求需要依赖于另一个网络请求的结果
-
思路1:操作依赖:NSOperation 操作依赖和优先级(不适用,异步网络请求并不是立刻返回,无法保证回调时再开启下一个网络请求)
|
1
|
[operationB addDependency:operationA]; // 操作B依赖于操作 |
-
思路2:逻辑判断:在上一个网络请求的响应回调中进行下一网络请求的激活(不适用,可能拿不到回调)
-
思路3:线程同步 -- 组队列(dispatch_group)
|
1
2
3
4
5
6
7
8
|
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);dispatch_group_t group = dispatch_group_create();dispatch_group_async(group, queue, ^{ /*加载图片1 */ });dispatch_group_async(group, queue, ^{ /*加载图片2 */ });dispatch_group_async(group, queue, ^{ /*加载图片3 */ }); dispatch_group_notify(group, dispatch_get_main_queue(), ^{ // 合并图片… …}); |
-
思路4:线程同步 --阻塞任务(dispatch_barrier):
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
/* 创建并发队列 */dispatch_queue_t concurrentQueue = dispatch_queue_create("test.concurrent.queue", DISPATCH_QUEUE_CONCURRENT);/* 添加两个并发操作A和B,即A和B会并发执行 */dispatch_async(concurrentQueue, ^(){ NSLog(@"OperationA");});dispatch_async(concurrentQueue, ^(){ NSLog(@"OperationB");});/* 添加barrier障碍操作,会等待前面的并发操作结束,并暂时阻塞后面的并发操作直到其完成 */dispatch_barrier_async(concurrentQueue, ^(){ NSLog(@"OperationBarrier!");});/* 继续添加并发操作C和D,要等待barrier障碍操作结束才能开始 */dispatch_async(concurrentQueue, ^(){ NSLog(@"OperationC");});dispatch_async(concurrentQueue, ^(){ NSLog(@"OperationD");}); |
-
思路5:线程同步 -- 信号量机制(dispatch_semaphore):
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
/* 创建一个信号量 */dispatch_semaphore_t semaphore = dispatch_semaphore_create(0);/* 任务1 */dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ /* 耗时任务1 */ NSLog(@"任务1开始"); [NSThread sleepForTimeInterval:3]; NSLog(@"任务1结束"); /* 任务1结束,发送信号告诉任务2可以开始了 */ dispatch_semaphore_signal(semaphore);});/* 任务2 */dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ /* 等待任务1结束获得信号量, 无限等待 */ dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER); /* 如果获得信号量则开始任务2 */ NSLog(@"任务2开始"); [NSThread sleepForTimeInterval:3]; NSLog(@"任务2结束");});[NSThread sleepForTimeInterval:10]; |

浙公网安备 33010602011771号