可以看到径筏,每個(gè)runloop中都創(chuàng)建一個(gè)Autorelease Pool带斑,并在runloop的末尾進(jìn)行釋放醋安,
所以柠辞,一般情況下,每個(gè)接受autorelease消息的對(duì)象踪栋,都會(huì)在下個(gè)runloop開始前被釋放囤官。也就是說(shuō)党饮,在一段同步的代碼中執(zhí)行過(guò)程中,生成的對(duì)象接受autorelease消息后不皆,一般是不會(huì)在代碼段執(zhí)行完成前釋放的鲫骗。
當(dāng)然也有讓autorelease提前生效的辦法:自己創(chuàng)建Pool并進(jìn)行釋放
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
NSArray * array = [[[NSArray alloc] init] autorelease];
[pool drain];
上面的array就會(huì)在[pool drain]執(zhí)行時(shí)被釋放沦寂。
所以對(duì)于你遇到的問(wèn)題,可以在for循環(huán)外嵌套一個(gè)Autorelease Pool進(jìn)行管理做修,例如
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
for (int i = 0; i < 10000; i++)
{
// ...
}
[pool drain];
但由于你提到了生成的每個(gè)實(shí)例可能會(huì)比較大霍狰。只在循環(huán)外嵌套,可能導(dǎo)致在pool釋放前饰及,內(nèi)存里已經(jīng)有10000個(gè)實(shí)例存在蔗坯,造成瞬間占用內(nèi)存過(guò)大的情況。
因此燎含,如果你的每個(gè)實(shí)例僅需要在單次循環(huán)過(guò)程中用到宾濒,那么可以考慮可以在循環(huán)內(nèi)創(chuàng)建pool并釋放
for (int i = 0; i < 10000; i++)
{
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
// ...
[pool drain];
}
如果還有疑問(wèn),可以參考下面幾篇資料:
How does the NSAutoreleasePool Work
http://stackoverflow.com/questions/65...
NSAutoreleasePool Class Reference
https://developer.apple.com/library/m...
Autorelease is fast:
http://www.mikeash.com/pyblog/autorel...