1.知识点
int main(int argc, char * argv[]) { @autoreleasepool { return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class])); } }
1.在每一个事件周期(event cycle)的开始,系统会自动创建一个自动释放池;在每一个事件周期的结尾,系统会自动销毁这个自动释放池。一般情况下可以理解为:当此APP的代码在持续运行时,自动释放池是不会被销毁的,这段时间内可以安全地使用自动释放的对象;当APP的代码运行告一段落,开始等待用户输入(或者其它事件)时,自动释放池就会被释放掉,池中的对象都会收到一个release消息,有的可能会因此被销毁。
2.当在主线程外开启其它线程时,系统只会在主线程中自动生成并销毁掉自动释放池。
2.例子
1.正常情况,属性为retain的应该使用autorelease,因为set方法会自动调用retain;属性为assign的不能使用。注意,只用使用self.retainView才会调用set方法,如果使用_retainView,则直接对内存赋值,不会调用set方法。
self.retainView = [[[UIView alloc]init]autorelease]; self.assignView = [[UIView alloc]init];
2.应该使用autorelease,因为在addGestureRecognizer时会自动retain。
UITapGestureRecognizer *tapGesture = [[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(doTap:)]autorelease]; tapGesture.delegate = self; [self.maskView addGestureRecognizer:tapGesture];
3.应该使用autorelease,因为cell要返回继续处理(返回后应该会retain),不能直接release。
cell = [tableView dequeueReusableCellWithIdentifier:@"cell"]; if(cell == nil){ cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:@"cell"] autorelease]; } return cell;
4.类级构造方法会自动调用autorelease,比如[NSMutableArray array]。如果此array为cell的内容,则正常加载cell没问题,加载完以后会随着autoreleasepool的释放被release。因此如果再刷新cell则会出错(比如上下滚动tableView)。因此要retain一次,或者使用对象级构造方法alloc。