NSString的一点tips

I have the following method

   -(NSMutableArray *) getPaises {
     
NSMutableArray * paises;
     paises
= [[NSMutableArray alloc] init];
     
while( get new row ) {
     
NSString *aPais =  [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 0)];
     
[paises addObject:aPais];
     
}
     
return paises;
   
}

I am not releasing the aPais, because if I do it the application crashes. I don't know when or if whether I should release it somewhere after using it and, if so, how do I do it. Just release the NSMutableArray is enough? Or do I have to traverse it and release each object?

And if I don't have to release it, who is the responsible for releasing?

link | improve this question


A note regarding method naming: In Cocoa, a method named “getFoo” returns foo by reference: - (void) getFoo:(out NSMutableArray **)outArray. To be consistent with Cocoa naming conventions, you should name your method simply “paises”. –  Peter Hosey Mar 2 '09 at 18:13
feedback

2 Answers

up vote 6 down vote accepted

As epatel said, you don't need to release that particular string. If you wanted to be more proactive, you could do this instead:

-(NSMutableArray *) getPaises {
   
NSMutableArray * paises;
    paises
= [[[NSMutableArray alloc] init] autorelease];
   
while( get new row ) {
       
NSString *aPais =  [[NSString alloc] initWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 0)];
       
[paises addObject:aPais];
       
[aPais release];
   
}
   
return paises;
}

In summary:

  • [[NSString alloc] initWith...] -> You must release or autorelease.

  • [NSString stringWith...] -> No need to release.

-- Edit: Added autorelease for paises, as you are returning it. When you return an object, always autorelease it if you have alloc&init'd it.

link | improve this answer


Thanks a lot. I'm releasing the NSMutableArray manually, but the autorelease is a better option. Gonna change it. –  Sacha Fuentes Mar 2 '09 at 14:30
feedback

stringWithUTF8String: returns an autorelease string which will be released automatically by Cocoa in the next eventloop. But the string is also retained in the array when you do addObject:...so as long as it is in the array it will be retained.

link | improve this answer

Was this post useful to you?     

你可能感兴趣的:(NSString)