2017-04-07 7 views
0

私は最近、インターネット接続が非常に遅く、GroundControlも使用しているクライアントの問題に直面しました。いつでもアプリを読み込もうとすると、「サーバーに接続しようとしています」読み込み画面が表示されなくなります。コードでは、成功または失敗のいずれも呼び出されていないので(ここではアプリが少なくとも進歩していれば)、ここで邪魔になるはずです(下のコードを参照)。AFHTTPSessionManagerフリーズ/デッドロックが発生しましたか?

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と何か関係がありますか?どのようにこのような状況に対処できますか?

答えて

0

私は問題を見つけ出しました。このコードスニペットが実行される前にオブジェクトourSyncClassが初期化されていない、コード内に論理的なバグがあったことがわかります。何らかの理由でこれが完了ブロックをデッドロックしていました。コードの周り (self.ourSyncClass!= nilの) {

}場合 だから、我々は のようなチェックが含まれており、今ではすべてが正常に動作しているようです。私はクライアントからの返答を得た後、アップデートを投稿します。

関連する問題