AFHTTPSessionManager GET冻结/正在死锁?
问题描述:
我最近遇到了一个客户谁有一个非常缓慢的互联网连接问题,也使用GroundControl。任何时候当他们尝试加载我的应用程序时,他们会卡在“正在尝试连接到服务器”加载屏幕上。我知道在代码中,它一定会被阻塞(见下面的代码),因为无论成功还是失败都不会被调用(如果它们是应用程序至少会提前)。AFHTTPSessionManager GET冻结/正在死锁?
NSURL *ourTable = [NSURL URLWithString:[[NSString stringWithFormat: @"%@://%@%@/bla/%@/bla/bla/Reachability",
(useSSLB == YES) ? @"https" : @"http", server, port, self.globalSettings.env]
stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
manager.responseSerializer = [AFJSONResponseSerializer serializer];
[manager GET:ourTable.absoluteString parameters:nil progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
NSLog(@"ONLINE..");
[self.ourSyncClass functionThatGetsCalledWhenSuccess;
[NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(syncOther) userInfo:nil repeats:NO];
startSync = YES; //Bool value used for other stuffs
NSLog(@"Syncing Data");
[manager invalidateSessionCancelingTasks:YES];
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
NSLog(@"FAILED TO CONNECT TO SERVER. %@", error);
self.offline = YES; //bool used for other stuff
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:1.0];
[self.homeViewControllerInstance.syncView setAlpha:0.0];
[UIView commitAnimations];
[self.ourSyncClass createDB];
[self.ourSyncClass openDB];
[self startCustomFunction;
[manager invalidateSessionCancelingTasks:YES];
}];
为什么我们的代码在此GET完成块中卡住(锁定?)?是否由于互联网连接速度慢?它可能与GroundControl有关吗?我该如何处理这种情况?
答
那么我最终发现了这个问题。原来我们的代码中存在一个逻辑错误,在这段代码执行之前,对象ourSyncClass没有被初始化。出于某种原因,这是完成块的死锁。 所以,我们包括像 一个检查,如果(self.ourSyncClass!=无) {
} 周围的代码,现在一切似乎正常工作。我们会在收到客户的回复后发布更新。