码迷,mamicode.com
首页 > 移动开发 > 详细

iOS 容易引“起循环引用”的三种场景

时间:2014-09-10 17:53:30      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:ios   循环引用   

笔者在阅读中总结了一下,在iOS平台容易引起循环引用的四个场景:

一、parent-child相互持有、委托模式

【案例】:

@interface FTAppCenterMainViewController ()
{
}

@property(weak,nonatomic) UITableView* myTableView;
@end
这里面的myTableView就使用了weak修饰符。

@property (nonatomic, weak)  id<FTActionSheetDelegate>delegate;

【推荐方法】:

child只有parent的对象为weak类型:

@property (nonatomic, weak)  id<FTActionSheetDelegate>delegate;

二、block

【案例】:

看下面的代码:

typedef void (^RequestNaviCallBack)(NSInteger naviCode,NSInteger httpCode,NSError * error);
@interface FtNaviManager : NSObject
{
}
@property (nonatomic, strong)   RequestNaviCallBack naviCallBack;
这是一个请求导航的类,类属性持有了RequestNaviCallBack,这时,如果RequestNaviCallBack再持有self,必然造成循环引用。

【推荐方法】:

如果有循环引用,编译器会提示警告。

如果对象没有持有Block对象,那么不会产生循环引用。如果对象持有了block对象,那么在block引用self的时候这么定义:

__weak typeof(self) weakSelf = self;

三、NSTimer

【案例】:

@interface FtKeepAlive : NSObject
{
    NSTimer*              _keepAliveTimer; // 发送心跳timer
}
//实现文件
_keepAliveTimer = [NSTimer scheduledTimerWithTimeInterval:_expired target:self selector:@selector(keepLiveStart) userInfo:nil repeats:YES];

类持有了_keepAliveTimer,_keepAliveTimer又持有了self,造成循环引用。

【推荐方法】:

NSTimer会持有对象,所以:在删除对象之前,需要将timer的invalidate方法。

-(void)stopKeepAlive{
    [_keepAliveTimer invalidate];
    _keepAliveTimer = nil;
}

iOS 容易引“起循环引用”的三种场景

标签:ios   循环引用   

原文地址:http://blog.csdn.net/hherima/article/details/39078545

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!