iOS AFNetWorking中block执行完后再执行其它操作

需求:同时进行两次网络请求,网络请求是异步的,在网络请求成功后进行其它的操作。两个网络请求是这样,一个网络请求中block执行完之后,再进行其它操作,也是一样的原理,只是这时候不需要线程组了,只需要信号量。当然也适用于所有的block。

接下来就说下,在两次异步请求之后要做的操作。

利用线程组和信号量来完成,看代码

- (void)getData

{

NSString *appIdKey = @"8781e4ef1c73ff20a180d3d7a42a8c04";

NSString* urlString_1 = @"http://api.openweathermap.org/data/2.5/weather";

NSString* urlString_2 = @"http://api.openweathermap.org/data/2.5/forecast/daily";

NSDictionary* dictionary [email protected]{

@"lat" : @"40.04991291",

@"lon" : @"116.25626162",

@"APPID" : appIdKey

};

// 创建队列组,可以使两个网络请求异步执行,执行完之后再进行操作

dispatch_group_t group = dispatch_group_create();

dispatch_group_async(group, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{

// 创建信号量

dispatch_semaphore_t semaphore = dispatch_semaphore_create(0);

AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];

[mgr GET:urlString_1 parameters:dictionary progress:^(NSProgress * _Nonnull downloadProgress) {

} success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {

// 请求成功发送信号量(+1)

dispatch_semaphore_signal(semaphore);

} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {

// 无论请求成功或失败都发送信号量(+1)

dispatch_semaphore_signal(semaphore);

}];

// 在请求成功之前等待信号量(-1)

dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

});

dispatch_group_async(group, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{

// 创建信号量

dispatch_semaphore_t semaphore = dispatch_semaphore_create(0);

AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];

[mgr GET:urlString_2 parameters:dictionary progress:^(NSProgress * _Nonnull downloadProgress) {

} success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {

// 发送信号量

dispatch_semaphore_signal(semaphore);

} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {

// 发送信号量

dispatch_semaphore_signal(semaphore);

}];

// 在请求成功之前等待信号量

dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);

});

// 请求完成之后

dispatch_group_notify(group, dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{

});

}

时间: 2024-10-15 23:38:39

iOS AFNetWorking中block执行完后再执行其它操作的相关文章

用一个bat文件调用另外两个bat文件,当1.bat执行完后再执行2.bat

摘自:https://zhidao.baidu.com/question/492732911.html @echo off start d:\1.bat start c:\2.bat 这样是2个任务同时执行,应该怎么改,谢谢 1 2 3 4 5 6 7 8 9 @echo off start /wait d:\1.bat start /wait c:\2.bat   @echo off call d:\1.bat call c:\2.bat start 是在新窗口运行调用的文件,call是在当前

C# 本进程执行完毕后再执行下一线程

最近做了一套MES集成系统,由上料到成品使自动化运行,其中生产过程是逐步的,但是每一个动作都需要独立的线程进行数据监听,那么就需要实现线程等待. 代码: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Thre

sharepoint等脚本加载完后再执行对应的方法

ExecuteOrDelayUntilScriptLoaded(myFunction,"sp.js"); //SP.SOD.executeFunc('sp.js', 'SP.ClientContext', myFunction); function myFunction() { //逻辑代码 } 原文地址:https://www.cnblogs.com/learning-life/p/10489959.html

java 多线程 , 等待所有子线程都执行完后 , 在执行主线程(其中的一种 , 也是个人觉得最好用的一种)

public static void main(String[] args) throws InterruptedException { // Runtime.getRuntime().availableProcessors() 获取可用的cpu数量 int count = Runtime.getRuntime().availableProcessors(); //创建一个指定线程数量的线程池 ExecutorService executorService = Executors.newFixe

JAVA设计方法思考之如何实现一个方法执行完毕后自动执行下一个方法

今天编程时,突然想起来在一些异步操作或Android原生库的时候,需要我们实现一些方法, 这些方法只需要我们具体实现,然后他们会在适当的时候,自动被调用! 例如AsyncTask,执行玩doInBackground()后会执行处理结果的postResult()方法,但我们并没有设置过他们的执行顺序. 以前只知道他们的运行原理,但不知道具体的实现方法,细想起来,这是一个相当不错的代码设计,所以决定研究一下. 因为一开始是通过实现方法来具体实现那些需要被执行的方法的,所以以为实现的方式是接口, 思索

java多线程笔试题---所有线程func1()执行完了,再执行func2()的实现

1.问题描述: 某个类有2个方法func1(),func2(),有threadCount个线程,要求所有线程执行完func1(),再执行func2(). 2.分析: 1)所有线程的func1()执行完的标准是什么? 2)线程之间怎样共享变量? 3.代码实现 1)源代码: /** * */ package com.sunny.www.interview; import java.util.concurrent.atomic.AtomicInteger; /** * 所有线程执行完方法1,再执行方法

在Struts.xml中的result元素指的是:指定动作类的动作方法执行完后的结果视图.

result结果集 上一篇文章主要讲Struts2框架(4)---Action类访问servlet这篇主要讲result结果集 在Struts.xml中的result元素指的是:指定动作类的动作方法执行完后的结果视图. (1)局部结果和全局结果 他有两个属性: name:字符串,与动作方法返回的值一致.默认是success type:指定处理结果的结果类型的别名.默认值是dispatcher 首先处理结果分为两种,一种是局部结果一种是全局结果. 局部结果: <action name="lo

C# 多线程join的用法,等待多个子线程结束后再执行主线程

等待多个子线程结束后再执行主线程 class MultiThread{ #region join test public void MultiThreadTest() { Thread[] ths = new Thread[2]; ths[0] = new Thread(Method1); ths[1] = new Thread(Method2); foreach (Thread item in ths) { //首先让所有线程都启动 item.Start(); //试想一下在这里加上item.

main函数执行前、后再执行的代码

一.main结束 不代表整个进程结束  (1)全局对象的构造函数会在main 函数之前执行,          全局对象的析构函数会在main函数之后执行:          用atexit注册的函数也会在main之后执行.  (2)一些全局变量.全局对象和静态变量.对象的空间分配和赋初值就是在执行main函数之前,而main函数执行完后,还要去执行一些诸如释放空间.释放资源使用权等操作  (3)进程启动后,要执行一些初始化代码(如设置环境变量等),然后跳转到main执行.全局对象的构造也在ma