循环引用的案例
-
一、parent-child相互持有、委托模式
【案例】:
这里面的myTableView就使用了weak修饰符。123456@interfaceFTAppCenterMainViewController (){}@property(weak,nonatomic) UITableView* myTableView;@end1@property(nonatomic, weak) id<ftactionsheetdelegate>delegate;</ftactionsheetdelegate>【推荐方法】:
child只有parent的对象为weak类型:
1@property(nonatomic, weak) id<ftactionsheetdelegate>delegate;</ftactionsheetdelegate>二、block
【案例】:
看下面的代码:
这是一个请求导航的类,类属性持有了RequestNaviCallBack,这时,如果RequestNaviCallBack再持有self,必然造成循环引用。12345typedefvoid(^RequestNaviCallBack)(NSInteger naviCode,NSInteger httpCode,NSError * error);@interfaceFtNaviManager : NSObject{}@property(nonatomic, strong) RequestNaviCallBack naviCallBack;【推荐方法】:
如果有循环引用,编译器会提示警告。
如果对象没有持有Block对象,那么不会产生循环引用。如果对象持有了block对象,那么在block引用self的时候这么定义:
1__weak typeof(self) weakSelf = self;三、NSTimer
【案例】:
123456@interfaceFtKeepAlive : NSObject{NSTimer* _keepAliveTimer;// 发送心跳timer}//实现文件_keepAliveTimer = [NSTimer scheduledTimerWithTimeInterval:_expired target:self selector:@selector(keepLiveStart) userInfo:nil repeats:YES];类持有了_keepAliveTimer,_keepAliveTimer又持有了self,造成循环引用。
【推荐方法】:
NSTimer会持有对象,所以:在删除对象之前,需要将timer的invalidate方法。
1234-(void)stopKeepAlive{[_keepAliveTimer invalidate];_keepAliveTimer = nil;}
1
浙公网安备 33010602011771号