Просмотр задержки перехода контроллера после NSURLConnection

Итак, это мой первый пост, я нашел этот сайт невероятно информативным в моей краткой истории программирования на Objective C и iOS. Во всяком случае, я столкнулся с проблемой своего рода. Краткое резюме: я пытаюсь написать форму входа, которая использует вызовы пользовательского класса, который обращается к веб-серверу для аутентификации с использованием NSURLConnection. Я использую протоколы и делегаты для делегирования обратно вызывающему классу для выполнения перехода к контроллеру представления главного меню после завершения аутентификации.

Проблема в том, что отображение меню, в которое я пытаюсь перейти, занимает от 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];
    }];
}

Все NSLogs выполняются в обычном промежутке времени (несколько миллисекунд). Тем не менее, контроллер представления главного меню появляется слишком долго! Я очень новичок в программировании для iOS, поэтому я надеюсь, что просто упускаю из виду то, что не смог решить поиск в Google. Любая помощь будет принята с благодарностью!


person pierceography    schedule 20.12.2012    source источник


Ответы (1)


Вам нужно обновить пользовательский интерфейс в основном потоке, но userLoginDone: вызывается в NSOperationQueue, который создает свой собственный отдельный поток. Это может объяснить задержку в отображении. Вы пытались использовать [NSOperationQueue mainQueue] (который возвращает очередь, связанную с основным потоком) для перехода к sendAsynchronousRequest: вместо этого?

person Peter E    schedule 20.12.2012
comment
Я изменил NSURLConnection на [NSURLConnection sendAsynchronousRequest:urlRequest queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *error), и теперь он работает отлично! Спасибо TON за вашу помощь! :-) - person pierceography; 20.12.2012