2012-07-23 2 views
6

ich versuchte zu machen - [NSString stringWithContentsOfURL: Codierung: Fehler:] asynchron, indem sie a-synchron von einem Hintergrund-Thread ausgeführt wird:Making stringWithContentsOfURL asynchron - Ist es sicher?

__block NSString *result; 
dispatch_queue_t currentQueue = dispatch_get_current_queue(); 

void (^doneBlock)(void) = ^{ 
    printf("done! %s",[result UTF8String]); 
}; 

dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 
             (unsigned long)NULL), ^(void) { 
    result = [NSString stringWithContentsOfURL:[NSURL URLWithString:@"http://www.google.com/"] encoding:NSUTF8StringEncoding error:nil]; 
    dispatch_sync(currentQueue, ^{ 
     doneBlock(); 
    }); 
}); 

Seine Arbeit gut, und was am wichtigsten ist, seine asynchron.

Meine Frage ist, ob es sicher ist, oder ob es Threading-Probleme etc. gibt?

Vielen Dank im Voraus :)

Antwort

27

, das sicher sein sollte, aber warum das Rad neu erfinden?

NSURLRequest *req = [NSURLRequest requestWithURL:[NSURL URLWithString:@"http://www.google.com"]]; 
[NSURLConnection sendAsynchronousRequest:req queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *error) { 
    NSString *result = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]; 
    // etc 
}]; 
+0

Prost! Ich wusste nicht, dass das möglich war: P – JonasG

+0

Zuerst dachte ich, dass dies wegen '[NSOperationQueue mainQueue]' in der Hauptwarteschlange funktioniert, aber dann sah ich 'sendAsynchronousRequest'. Das sollte die Aktualisierung der Benutzeroberfläche nicht stoppen. –

0

Sie können auch verwenden:

dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0); 

dispatch_async(queue, ^{ 
     NSError *error = nil; 
     NSString *searchResultString = [NSString stringWithContentsOfURL:[NSURL URLWithString:searchURL] 
                  encoding:NSUTF8StringEncoding 
                   error:&error]; 
     if (error != nil) { 
      completionBlock(term,nil,error); 
     } 
     else 
     { 
      // Parse the JSON Response 
      NSData *jsonData = [searchResultString dataUsingEncoding:NSUTF8StringEncoding]; 
      NSDictionary *searchResultsDict = [NSJSONSerialization JSONObjectWithData:jsonData 
                       options:kNilOptions 
                       error:&error]; 
      if(error != nil) 
      { 
       completionBlock(term,nil,error); 
      } 
      else 
      { 

       //Other Work here 
      } 
     } 
    }); 

Aber ja, es sollte sicher sein. Mir wurde gesagt, dass NSURLConnection stattdessen wegen Fehleranrufen und dergleichen bei der Kommunikation über das Internet verwendet werden soll. Ich forsche immer noch daran.

0
-(void)loadappdetails:(NSString*)appid { 
    NSString* searchurl = [@"https://itunes.apple.com/lookup?id=" stringByAppendingString:appid]; 

    [self performSelectorInBackground:@selector(asyncload:) withObject:searchurl]; 

} 
-(void)asyncload:(NSString*)searchurl { 
    NSURL* url = [NSURL URLWithString:searchurl]; 
    NSError* error = nil; 
    NSString* str = [NSString stringWithContentsOfURL:url encoding:NSUTF8StringEncoding error:&error]; 
    if (error != nil) { 
     NSLog(@"Error: %@", error); 
    } 
    NSLog(@"str: %@", str); 
}