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!=无) {

} 周围的代码,现在一切似乎正常工作。我们会在收到客户的回复后发布更新。