Объект в методе утечки - PullRequest
0 голосов
/ 01 марта 2012

есть еще одна проблема с утечкой. У меня есть метод:

-(NSMutableArray*)returnItems:(int)nominalID subCountryID:(int)subCountryID
{
NSArray *paths =
NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0]; 
NSString *path =
[documentsDirectory stringByAppendingPathComponent:databaseName];

NSMutableArray *itemsArray=[[[NSMutableArray alloc]init]autorelease];

if (sqlite3_open([path UTF8String], &database) == SQLITE_OK)
{
    const char *sqlItems=sqlite3_mprintf("SELECT itm.itemID,itm.itemYear,itm.rarity,itm.mintage,iaval.availability as avalibility,iaval.quality as quality,itm.Mintmark,itm.specialRemark,iaval.dated\
                                         from items as itm\
                                         inner join itemAvailability as iaval on itm.itemID=iaval.itemID\
                                         INNER join NominalsAndSubcountriesRelation as nasr on nasr.nominalID=itm.relatedToNominal\
                                         WHERE nasr.nominalID=%i AND nasr.subCountryID=%i",nominalID,subCountryID);

sqlite3_stmt *statement;
int sqlResult = sqlite3_prepare_v2(database, sqlItems, -1, &statement, NULL);
if ( sqlResult== SQLITE_OK)
{
    while (sqlite3_step(statement) == SQLITE_ROW)
    {
        Item *item=[[Item alloc]init];
        item.itemID=sqlite3_column_int(statement, 0);
        char *itemYear=(char *)sqlite3_column_text(statement, 1);
        item.rarity=sqlite3_column_int(statement, 2);
        char *mintage=(char *)sqlite3_column_text(statement, 3);
        item.availability=sqlite3_column_int(statement, 4);
        item.quality=sqlite3_column_int(statement, 5);
        char *mintmark=(char *)sqlite3_column_text(statement, 6);
        char *specialRemark=(char*)sqlite3_column_text(statement, 7);
        char *dated=(char*)sqlite3_column_text(statement, 8);
        item.itemYear=(itemYear)?[NSString stringWithUTF8String:itemYear]:@"";
        item.mintage=(mintage)?[NSString stringWithUTF8String:mintage]:@"Unknown";
        item.mintmark=(mintmark)?[NSString stringWithUTF8String:mintmark]:@"";
        item.specialRemark=(specialRemark)?[NSString stringWithUTF8String:specialRemark]:@"";
        item.dated=(dated)?[NSString stringWithUTF8String:dated]:@"";
        [itemsArray addObject:item];
        [item release];
    }
    sqlite3_finalize(statement);
    sqlite3_free((char*)sqlItems);
}
}
else
{
    [self dbConnectionError];
}

    return itemsArray;
}

Инструментальный инструмент утверждает, что утечка на объекте предмета составляет 100% Что с ним не так?

Ответы [ 2 ]

1 голос
/ 01 марта 2012

Ничто не кажется неправильным в коде, который вы предоставляете;item высвобождается после добавления в itemsArray, а itemsArray автоматически высвобождается, поэтому возвращается как ссылка, не являющаяся владельцем.

Поэтому вы должны исходить из того, что тот, кто получает itemsArray, сохраняет его и не может его выполнить.отпустите.

1 голос
/ 01 марта 2012

Я не вижу утечек в этом коде.

Инструменты сообщают вам, какой объект просочился и где он был выделен. Это распределение не обязательно там, где происходит утечка.

Итак: где вы используете элементы из этого массива? Где-то вы сохраняете элемент из массива, не освобождая его. (Или, возможно, весь массив.)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...