I use NSURLSessionTask
s and I'm trying to monitor how long some of my HTTP Requests take, what delegate method (or something else) can I monitor for when the NSURLSessionTask
actually makes the initial request? If this were a NSURLConnection
inside an NSOperation
I'd just start a timer when I start the request but I don't have control over when tasks start.
相关问题
- CALayer - backgroundColor flipped?
- Core Data lightweight migration crashes after App
- How can I implement password recovery in an iPhone
- State preservation and restoration strategies with
- “Zero out” sensitive String data in Swift
相关文章
- 现在使用swift开发ios应用好还是swift?
- UITableView dragging distance with UIRefreshContro
- TCC __TCCAccessRequest_block_invoke
- Where does a host app handle NSExtensionContext#co
- xcode 4 garbage collection removed?
- Unable to process app at this time due to a genera
- Swift - hide pickerView after value selected
- How can I add media attachments to my push notific
Two options:
If you want, you could implement the delegate based rendition of
NSURLSession
and then capture the elapsed time betweendidReceiveResponse
anddidCompleteWithError
. This admittedly doesn't capture the latency involved in receiving the response, but if you're looking for a simple measure that factors out the time waiting for an available connection, that's one approach.The other approach is to wrap the
NSURLSessionTask
objects in aNSOperation
subclass, just like you did withNSURLConnection
. This is trivial in the case where you are using the completion block rendition of theNSURLSessionTask
factory methods. It's a little more cumbersome when using the delegate based approach (because, infuriatingly,NSURLSession
doesn't allow us to specify delegate objects for the individual tasks (even though they let us associate completion blocks for them), but rather all of the task-specific delegate methods are called at the session object level).Anyway, when you wrap it in a
NSOperation
subclass, you can capture your complete elapsed time quite easily.Please check NSURLSessionTaskDelegate. It has following delegate callbacks:
To calculate time interval.
Option 01 [Approximate]:
You should start a timer just after the call to resume method and and calculate when the delegate callback didCompleteWithError is invoked.
Option 02 [If accuracy is desired]:
NSURLSessionTask’s properties are all KVO-compliant.
I know this is an old question but for those searching the delegate method func urlSession(_ session: URLSession, task: URLSessionTask, didFinishCollecting metrics: URLSessionTaskMetrics) on URLSessionTaskDelegate should be able to provide plenty of info about the request including how long it took.