最近项目中出现一个需求.就是有可能要对成百甚至上千条数据进行修改. 但是服务器那边不愿意提供批量操作的接口. 只能自己实现了. 首先感谢AFNetworking. 因为他.我才能方便的实现这个需求.
先说思路吧. 手机的内存是有限的, 我们如果不顾后果,一次性创建大量的请求发出, 这绝对是会影响性能的. 所以我们要限制请求的最大并发数,同一时间最多只能发送5个或者10个的请求, 某个请求完成了,就继续发送下个请求.
直接上代码.先是.h.
首先我们来看看代码:
name是该工具的名字. 方便在接下来的使用.
代理的作用是当全部任务执行完毕的时候告诉外面.
参数数组是用于发送请求的,可以在创建这个类的时候赋值,或者在之后赋值.
接下来是一个bool.该值决定是否要继续执行任务.
最后是一个开始任务的方法,通过block执行回调.
然后是.m:
这里有个manager属性.是用于发送请求的.
然后就是在创建对象的时候调用一个baseSetUp方法,对manager初始化.
接下来就是具体发送请求的方法:
首先判断是否被cancel了. 是的话.就直接调用代理方法
然后再判断参数数组的个数是否为0, 如果不是的话,就取出数组的第一个参数, 使用manager发出, 在成功或者失败的回调里面, 先把参数从数组中移除, 然后通过自身的block把参数告诉外面. 再继续调用这个方法.
直到最后请求数组已经为空了. 就调用代理方法告诉外界所有任务都已经处理完毕了.
这就是这个工具类的全部了. 但是这个工具也只是实现了同一时间发送一个请求. 请求回来后,无论成功与否,都继续发送下个请求. 与并发请求还差着十万八千里呢.
所以我们需要创建一个管理类, 专门管理多个工具.有10个工具,我们就能同时发送10个请求了.
先是.h文件:
属性的话只有两个,一个是最大并发数,一个是代理.
然后是创建方法, 还有开始任务,以及取消任务的方法.
代理的话,就是成功,失败,以及所有任务完毕后的回调.
然后是.m文件:
属性的话也只有两个. 一个是用于保存工具的数组,一个是已完成任务的个数.
然后是方法, 重写了最大并发数的set方法.
然后是开始任务的时候,需要给工具派发任务. 派发任务是把请求的个数平分. 当然,最后一个工具的任务不一定平均数,需要特殊处理.
派发完毕之后,就遍历工具数组, 依次发起请求.我们再通过回调告诉外界.
然后是取消任务的方法,也是遍历,设置工具的cacel属性为yes就可以了.
最后.当某个工具任务执行完毕后,就会调用工具的完成任务的回调方法. 在这里,我们做个判断. 当全部执行完毕后, 再告诉外界就可以了.
github上demo的地址:https://github.com/byljbdh/ALNMultipleNetworkTool
以上.