views:

86

answers:

1

In the CocoaXMLParser class of Apple's CocoaXMLParser example, the following code appears:

 rssConnection = [[NSURLConnection alloc] initWithRequest:theRequest delegate:self];
[self performSelectorOnMainThread:@selector(downloadStarted) withObject:nil waitUntilDone:NO];
if (rssConnection != nil) {
    do {
        [[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]];
    } while (!done);
}

According to the NSRunLoop documentation "In general, your application does not need to either create or explicitly manage NSRunLoop objects. Each NSThread object, including the application’s main thread, has an NSRunLoop object automatically created for it as needed." In the context of this, why is the run-loop explicitly managed in this example? Would it not be created and destroyed automatically by the thread generated by the NSURLConnection request?

+2  A: 

In that code, the run loop is basically just being told to run forever, so that that thread can continue to process incoming background data from the NSURLConnection. Even though a run-loop is created for you, by default the thread would terminate when that method ended.

In general when doing something like that it's easier to put everything in an NSOperation which then goes in an NSOperationQueue (although if you are implementing NSUrlConnection callbacks you have to provide a few extra methods in the NSOperation class).

Kendall Helmstetter Gelner
Thanks, so are you saying that the thread (in this case for a NSURLConnection) could terminate before the connectionDidFinishLoading method is called?
Run Loop
Exactly, in fact I have run into this exact problem before in real life -you open a valid connection, and then connectionDidFinishLoading is never called... nor are any of the other methods like didReceiveData. In that case the background thread you were trying to load on terminated before the URL connection could even do anything.
Kendall Helmstetter Gelner