執行autorelease方法的對象什麼時候被釋放。

wKioL1Q7z0zizoP7AADAbmalz48648.gifOS的運行時是由一個一個runloop組成的,每個runloop都會執行下圖的一些步驟:

可以看到,每個runloop中都創建一個Autorelease Pool,並在runloop的末尾進行釋放,所以,一般情況下,每個接受autorelease消息的對象,都會在下個runloop開始前被釋放。也就是說,在一段同步的代碼中執行過程中,生成的對象接受autorelease消息後,一般是不會在代碼段執行完成前釋放的。
當然也有讓autorelease提前生效的辦法:自己創建Pool並進行釋放
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
NSArray * array = [[[NSArray alloc] init] autorelease];
[pool drain];
上面的array就會在[pool drain]執行時被釋放。
所以對於你遇到的問題,可以在for循環外嵌套一個Autorelease Pool進行管理,例如
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
for (int i = 0; i < 10000; i++)
{
    // ... 
}
[pool drain];
但由於你提到了生成的每個實例可能會比較大。只在循環外嵌套,可能導致在pool釋放前,內存裏已經有10000個實例存在,造成瞬間佔用內存過大的情況。
因此,如果你的每個實例僅需要在單次循環過程中用到,那麼可以考慮可以在循環內創建pool並釋放
for (int i = 0; i < 10000; i++)
{
    NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
    // ...
    [pool drain];
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章