0

在以下代码片段中:

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

while (sqlite3_step(fetch_statement)==SQLITE_ROW){

    int pk =    sqlite3_column_int(fetch_statement,0);  

    Item_A *itemA = [[Item_A alloc] getItemA:pk fromDatabase:db];

    // calculate and set a property of itemA
    [itemA setValue:xValue forkey:xKey];

    // insert into array
    [tmpItemsArray addObject:itemA];
    [itemA release];
}
sqlite3_reset(fetch_statement);

// for each ItemA in array      
    // update itemA in database
for (Item_A *eachItemA in tmpItemsArray) {
    [eachItemA updateItemAInDatabase:db];
}

当我使用 addObject: 方法将对象添加到 tmpItemsArray 时,itemA 指向的内存地址处的对象被添加到数组中。换句话说,tmpItemsArray 中的对象指向的内存地址与 ItemA 指向的内存地址相同。

现在当 [itemA release] 被执行时,释放内存 -

tmpItemsArray 会有指向无效内存的对象吗

或者

[itemA release] 是否仅释放 itemA 对此内存的持有(以某种方式)?

4

2 回答 2

0

不,当[itemA release]被调用时,计数器递减并且仅当计数器达到零时才释放内存。每次有人声称拥有该对象的所有权时(例如当输入一个数组时),计数器就会增加。

于 2012-07-04T17:14:40.000 回答
0

release实际上不会导致内存被释放。相反,它会减少一个计数,该计数表示代码的某些部分保留了对象的次数。分配对象的行为相当于一种保留,而将其添加到数组中则是另一种。您的release平衡,alloc并且在这一点上,数组的保留阻止它被释放。

当数组消失时,除非发生其他事件,否则它将释放其内容。由于它是一个自动释放的数组,这很可能发生在程序事件循环的下一次迭代中。

于 2012-07-04T17:15:23.417 回答