Мой контроллер получить данные из функции в delegat:утечки памяти в делегатом
- (NSArray *)getChapters {
NSMutableArray *list = [[NSMutableArray alloc] init]; //memory leak
if (chapter_statement == nil) {
const char *sql = "SELECT DISTINCT 'Глава '||chapter FROM verses WHERE book=? ORDER by chapter";
if (sqlite3_prepare_v2(database, sql, -1, &chapter_statement, NULL) != SQLITE_OK) {
NSAssert1(0, @"Error: failed to prepare statement with message '%s'.", sqlite3_errmsg(database));
}
}
sqlite3_bind_int(chapter_statement, 1, self.book);
while (sqlite3_step(chapter_statement) == SQLITE_ROW) {
NSString *body = [NSString stringWithUTF8String:(char *)sqlite3_column_text(chapter_statement, 0)];
[list addObject:body];
[body release];
}
sqlite3_reset(chapter_statement);
return list;
}
и использовать его в контроллере:
- (void)viewWillAppear:(BOOL)animated {
AppDelegate *appDelegate = (AppDelegate *)[[UIApplication sharedApplication] delegate];
self.listChapters = [[NSArray alloc] initWithArray:[appDelegate getChapters]];
[self.listChapters release];
}
Утечки показывает утечку памяти в: NSMutableArray *list = [[NSMutableArray alloc] init];
Если я вернуться, как return [list autorelease];
сбой приложений в viewWillAppear
. Как исправить эту проблему?
Да, это работает, но теперь утечки показывают утечку в - [NSPlaceholderString initWithBytes: length: encoding:] в Foundation –
Я подозреваю, что утечка исходит откуда-то еще. Если вы еще этого не сделали, проверьте FMDB (http: // gusmueller.com/blog/archives/2008/06/new_home_for_fmdb.html) Это базовая оболочка Cocoa для Sqlite, которая может сэкономить вам много горящих вызовов БД. –