iOS 初探 AFNetworking
2020/7/15 23:09:39
本文主要是介绍iOS 初探 AFNetworking,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
本文不对AFNetworking
作全面的解析,仅对比解析一下2.x
和3.x
的差异。
AFNetworking
分为如下5个功能模块
:
- 网络通信模块(
AFURLSessionManager、AFHTTPSessionManger
) - 网络状态监听模块(
Reachability
) - 网络通信安全策略模块(
Security
) - 网络通信信息序列化/反序列化模块(
Serialization
) - 对于
iOS UIKit
库的扩展(UIKit
)
-
AFNetworking 2.x
需要常驻线程而3.x
不需要常驻线程2.x
常驻线程用来并发请求和处理数据回调
,避免多个网络请求的线程开销(不用开辟一个线程,就保活一条线程
);而3.x
不需要常驻线程是因为NSURLSession
可以指定回调delegateQueue
,NSURLConnection
不行;NSURLConnection
的一大痛点就是:发起请求后,需要一直处于等待回调的状态
。而3.x
后NSURLSession
解决了这个问题;NSURLSession
发起的请求,不再需要在当前线程进行回调,可以指定回调的delegateQueue
,这样就不用为了等待代理回调方法而保活线程了 -
3.x
需要设置最大并发数为1
(self.operationQueue.maxConcurrentOperationCount = 1
),2.x
为什么不需要 功能不一样:3.x
的operationQueue
是用来接收NSURLSessionDelegate
回调的,鉴于一些多线程数据访问的安全性考虑,设置了maxConcurrentOperationCount = 1
来达到并发的请求串行的进行回调
的效果。而2.x
的operationQueue
是用来添加operation
进行并发请求
的,所以不要设置为1
注意:并发数并不等于所开辟的线程数,具体开辟几条线程由系统决定 -
3.x
为什么要串行回调
- (AFURLSessionManagerTaskDelegate *)delegateForTask:(NSURLSessionTask *)task { NSParameterAssert(task); AFURLSessionManagerTaskDelegate *delegate = nil; [self.lock lock]; //给所要访问的资源加锁,防止造成数据混乱 delegate = self.mutableTaskDelegatesKeyedByTaskIdentifier[@(task.taskIdentifier)]; [self.lock unlock]; return delegate; } 复制代码
从代码可以看出,这边对self.mutableTaskDelegatesKeyedByTaskIdentifier
的访问进行了加锁,目的是保证多线程环境下的数据安全
。既然加了锁,就算maxConcurrentOperationCount
不设为1
,当某个请求正在回调时,下一个请求还是得等待一直到上个请求获取完所要的资源后解锁,所以这边并发回调也是没有意义的。相反多task
回调导致的多线程并发,还会导致性能的浪费
附:我的博客地址
这篇关于iOS 初探 AFNetworking的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2022-10-05Swift语法学习--基于协议进行网络请求
- 2022-08-17Apple开发_Swift语言地标注释
- 2022-07-24Swift 初见
- 2022-05-22SwiftUI App 支持多语种 All In One
- 2022-05-10SwiftUI 组件参数简写 All In One
- 2022-04-14SwiftUI 学习笔记
- 2022-02-23Swift 文件夹和文件操作
- 2022-02-17Swift中使用KVO
- 2022-02-08Swift 汇编 String array
- 2022-01-30SwiftUI3.0页面反向传值