これが私の最初の投稿です。ObjectiveCとiOSプログラミングの短い歴史の中で、このサイトは非常に有益であることがわかりました。とにかく、私はある種の問題に遭遇しました。簡単な要約:ログインフォームを作成しようとしています。このフォームでは、NSURLConnectionを使用して認証するためにWebサーバーにアクセスするカスタムクラスを呼び出します。認証が完了したら、プロトコルとデリゲートを使用して呼び出し元のクラスにデリゲートし、メインメニュービューコントローラーへのセグエを実行しています。
問題は、私がセグエしようとしているメニューが表示されるまでに6〜75秒かかることです。API呼び出しを削除すると、すぐに読み込まれます。ただし、私はプロセス全体でロギングを行っており、すべてが通常のペースで進んでいるように見えます。メニュービューコントローラがロードされたときにもログに記録しますが、すべてのログ記録は正常に行われます。しかし、メニューの実際の表示は遅れます!
コードの詳細は次のとおりです。
コントローラーメソッドの表示:
- (void) userLogin:(NSString *)userName password:(NSString *)password {
NSLog(@"VC login method");
api = [theAPI getSelf];
[api setDelegate:self];
[api userLogin:userName password:password];
}
- (void) userLoginDone:(BOOL)successful {
[self performSegueWithIdentifier:@"sgLoginToMainMenu" sender:self];
NSLog(@"Login Done");
}
APIメソッド:
- (void) userLogin:(NSString *)userName password:(NSString *)password {
NSURL *url = [NSURL URLWithString:(NSString *) [API_PATH stringByAppendingString:@"test.html"]];
NSURLRequest *urlRequest = [NSURLRequest requestWithURL:url];
NSOperationQueue *queue = [[NSOperationQueue alloc] init];
[NSURLConnection sendAsynchronousRequest:urlRequest queue:queue completionHandler:^(NSURLResponse *response, NSData *data, NSError *error) {
NSDictionary *json = [[JSON new] parseJSON:data];
self.usrID = [json objectForKey:@"usrID"];
self.sessionID = [json objectForKey:@"sessionID"];
self.userName = [json objectForKey:@"Username"];
NSLog(@"Username: %@", [json objectForKey:@"Username"]);
[[self delegate] userLoginDone:YES];
}];
}
すべてのNSLogは、通常のタイムスパン(数ミリ秒)で実行されます。それでも、メインメニュービューコントローラーが表示されるまでに時間がかかりすぎます。私はiOSプログラミングに非常に慣れていないので、グーグルで解決できない何かを見落としていることを望んでいます。どんな助けでも大歓迎です!