I created DownloadAndParseBook class. It will not autorelesed before it gеt any data or network error.
I used [self release], [self retain]. Is it good approach to use [self release], [self retain]? Is DownloadAndParseBook contain any potential bugs?
@implementation GetBooks
-(void) books
{
for(int i =0; i<10; i++)
{
DownloadAndParseBook *downloadAndParseBook =
[[[DownloadAndParseBook alloc] init]autorelease];
[downloadAndParseBook startLoadingBook];
}
}
@end
@implementation DownloadAndParseBook
- (id)initWithAbook:(int)bookID
{
if(self = [super init])
{
[self retain];
}
return self;
}
- (void)startLoadingBook
{
[NSURLConnection connectionWithRequest:request delegate:self];
}
- (void)connection:(NSURLConnection *)connection didFailWithError:(NSError *)error
{
[self release];
}
- (void)connectionDidFinishLoading:(NSURLConnection *)connection
{
[self saveResultToDatabase];
[self release];
}
@end
Self retaining is very occasionally an appropriate pattern. It’s rare, but sometimes in certain kinds of multi-threaded code its important to make sure that you don’t vanish in the middle of processing something. That said, this is not one of those times. I’m having trouble imagining a case where your current approach would be helpful. If someone creates your object and then never calls
startLoadingBook, then it leaks. If someone callsstartLoadingBook, then your object is retained anyway, becauseNSURLConnectionretains its delegate until it finishes.That said, I believe much of your problem is coming from the fact that your object model is wrong. Neither
GetBooksnorDownloadAndParseBookmake sense as classes. What you likely mean isBookManager(something to hold all the books) andBookDownloadController(something to manage the downloading of a single book). TheBookManagershould keep track of all the currentBookDownloadControllers(in anNSSetorNSArrayivar). EachBookDownloadControllershould keep track of itsNSURLConnection(in an ivar). You should not just create connections and have them “hang on themselves” (i.e. self-retain). This feels convenient, but it makes the code very hard to deal with later. You have no way to control how many connections you’re making. You have no way to cancel connections. It becomes a mess really quickly.