看了这之后,想起了之前看懂的一些东西,ObjC的内存管理用的是引用计数,当这个计数为0时,就dealloc。
1,alloc, allocWithZone,new(带初始化)
2,release
3,retain
4,copy,mutableCopy
5,autorelease
1,3,4会使计数增加,2,5会使计数减少,两者要一对一出现,保证内存不泄露,使用属性访问器的时候要小心,
- (void)setMyArray:(NSMutableArray *)newArray {
if (myArray != newArray) {
[myArray release];
myArray = [newArray retain];
}
}
然后就是试验NSString的几个初始化方法,
NSString *s1 = @"const"; 这种的引用计数是-1,
initWithFormat,手动release
stringWithFormat,autorelease
stringWithString,autorelease
还个这种问题,当release后,输出的retianCount还是1,因为虽然指向的空间被释放掉,可被系统使用,但该指针指向的内容可能还没被擦写,所以就是原来的值了,参加这。
NSString *s = [[NSString alloc] initWithFormat: @"test"]; NSLog(@"%d", [s retainCount]); [s release]; // s = nil; NSLog(@"%d", [s retainCount]);
对于屏蔽掉ARC,仍然出现@autoreleasepool块,而非原来的生成NSxxxpool,然后release pool的形式的解释,可以看这,大意是,这跟之前的是等价的,而且在高版本中,速度更快。