在NSURLConnection之后查看控制器Segue延迟

时间:2012-12-20 04:50:47

标签: objective-c ios xcode nsurlconnection segue

所以这是我的第一篇文章,我在Objective C和iOS编程的简史中发现这个网站提供了非常丰富的信息。无论如何,我遇到了各种各样的问题。快速摘要:我正在尝试编写一个登录表单,该表单使用调用自定义类来调用Web服务器以使用NSURLConnection进行身份验证。我正在使用协议和委托委托给调用类,以便在身份验证完成后对主菜单视图控制器执行segue。

问题是我试图进入的菜单需要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编程很新,所以我希望我只是忽略了谷歌搜索无法解决的问题。任何帮助将不胜感激!

1 个答案:

答案 0 :(得分:4)

您需要更新主线程上的UI,但是在NSOperationQueue上调用userLoginDone:会创建自己的单独线程。这可以解释显示的延迟。您是否尝试使用[NSOperationQueue mainQueue](返回与主线程关联的队列)传递给sendAsynchronousRequest:而不是?