NSURLConnection não chama completo em várias exibições

Hoje cedo fiz a seguinte pergunta:Bloco do iOS sendo interrompido quando o modo de exibição é pressionado

A operação que mencionei (OP1) é na verdade uma "http get" para o meu servidor, usando NSURLConnection.
Depois de mais investigação, descobri que o bloco não "morre" realmente. O que realmente acontece é que a requisição é realmente SENT (o lado do servidor a registra), mesmo depois que a view é pressionada (verificada via [NSThread sleep: 10]). O servidor responde, mas NADA acontece no lado do aplicativo se a view2 foi pressionada! quase como se a conexão tivesse perdido seu delegado! Outra possibilidade que eu estou olhando é "o fato de que NSURLConnection está norsMainLoop relacionado? "

Alguém pode ajudar?

Pls não esquece que:
0. Tudo funciona bem, desde que a view2 não seja pressionada até a conclusão da operação.
1. O pedido é enviado assíncrono
2. Eu defino o delegado e ele funciona enquanto a exibição não mudar
3. ver1 inicia a operação usando a propriedade "referência do objeto singleton" "OP1Completed"
4. ver2 verifica a conclusão do OP1 via propriedade na "referência de objeto singleton"
5. ver2 Obtém o "resultado", indo para a propriedade "singleton.OP1Result"

Editar 1:
Ok, vamos ter algum código. Primeiro aqui está o código relevante do meu singleton (chamado "Interaction"):

-(void)loadAllContextsForUser:(NSString *)username{
userNameAux = username;
_loadingContextsCompleted = NO;
if (contextsLoaderQueue == NULL) {
    contextsLoaderQueue = dispatch_queue_create("contextsLoaderQueue", NULL);
}

dispatch_async(contextsLoaderQueue, ^{
    NSLog(@"Loading all contexts block started");
    [self requestConnectivity];

    dispatch_async(dispatch_get_main_queue(), ^{
        [Util Get:[NSString stringWithFormat:@"%@/userContext?username=%@", Util.azureBaseUrl, [username stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]]
     successBlock:^(NSData *data, id jsonData){
         NSLog(@"Loading all contexts block succeeded");
         if([userNameAux isEqualToString:username]){
             _allContextsForCurrentUser = [[NSSet alloc]initWithArray: jsonData];
         }
     } errorBlock:^(NSError *error){
         NSLog(@"%@",error);
     } completeBlock:^{
         NSLog(@"load all contexts for user async block completed.");
         _loadingContextsCompleted = YES;
         [self releaseConnectivity];
     }];
    });

    while (!_loadingContextsCompleted) {
        NSLog(@"loading all contexts block waiting.");
        [NSThread sleepForTimeInterval:.5];
    }
});
NSLog(@"Load All Contexts Dispatched. It should start at any moment if it not already.");
}

E aqui está a classe Util, que realmente lida com o pedido / resposta

-(id)initGet:(NSString *)resourceURL successBlock:(successBlock_t)successBlock errorBlock:(errorBlock_t)errorBlock completeBlock:(completeBlock_t)completeBlock;{
if(self=[super init]){
    _data=[[NSMutableData alloc]init];
}

_successBlock = [successBlock copy];
_completeBlock = [completeBlock copy];
_errorBlock = [errorBlock copy];

NSURL *url = [NSURL URLWithString:resourceURL];
NSMutableURLRequest *request = [NSURLRequest requestWithURL:url];
[[NSURLConnection alloc] initWithRequest:request delegate:self startImmediately:YES];
//[_conn scheduleInRunLoop:[NSRunLoop mainRunLoop] forMode:NSDefaultRunLoopMode];
//[_conn start];
NSLog(@"Request Started.");

return self;
}

- (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response
{
    [_data setLength:0];
}

- (void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data
{
    [_data appendData:data];
}
- (void)connectionDidFinishLoading:(NSURLConnection *)connection
{
id jsonObjects = [NSJSONSerialization JSONObjectWithData:_data options:NSJSONReadingMutableContainers error:nil];

id key = [[jsonObjects allKeys] objectAtIndex:0];
id jsonResult = [jsonObjects objectForKey:key];

_successBlock(_data, jsonResult);
_completeBlock();
}

- (void)connection:(NSURLConnection *)connection didFailWithError:(NSError *)error
{
_errorBlock(error);
_completeBlock();
}

E finalmente aqui está a parte relevante VC1 (empurrando em VC2)

- (IBAction)loginClicked {
NSLog(@"login clicked. Preparing to exibit next view");

UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard_iPhone" bundle:nil];
AuthenticationViewController *viewController = (AuthenticationViewController *)[storyboard instantiateViewControllerWithIdentifier:@"ContextSelectionView"];

NSLog(@"Preparation completed. pushing view now");

[self presentViewController:viewController animated:YES completion:nil];
}

questionAnswers(5)

yourAnswerToTheQuestion