我正在使用ARC编写iOS应用程序,目标版本为iOS 5+。
假设我编写了一个自定义视图对象,该对象具有委托属性。在声明委托属性时,我将其设置为弱引用以避免保留循环,这样当实际的委托对象(控制器)被销毁时,我的自定义视图也会被销毁,如下所示:
我的问题是:我是否需要重写dealloc方法来将两个代理都设置为nil?
我的意思是,据我所了解,UIKit视图(在这种情况下为tableView)的delegate属性实际上并没有声明为弱引用,而是一个__unsafe_unretained引用,以便与非ARC版本的iOS向后兼容。因此,也许我需要编写
假设我编写了一个自定义视图对象,该对象具有委托属性。在声明委托属性时,我将其设置为弱引用以避免保留循环,这样当实际的委托对象(控制器)被销毁时,我的自定义视图也会被销毁,如下所示:
@interface MyCustomView : UIView
@property (nonatomic, weak) id<MyCustomViewDelegate> delegate;
@end
一切都很好。
好的,现在我正在编写控制器对象,它引用了两个视图对象:我的自定义视图和一个由苹果提供的UIKit视图,两者都声明了委托属性,并且控制器是这两个视图的委托。也许它看起来像这样:
@interface MyViewController : UIViewController <MyCustomViewDelegate, UITableViewDataSource, UITableViewDelegate>
@property (nonatomic, strong) MyCustomView *customView;
@property (nonatomic, strong) UITableView *tableView;
@end
@implementation MyViewController
- (void)viewDidLoad
{
self.customView.delegate = self;
self.tableView.dataSource = self;
self.tableView.delegate = self;
}
@end
我的问题是:我是否需要重写dealloc方法来将两个代理都设置为nil?
我的意思是,据我所了解,UIKit视图(在这种情况下为tableView)的delegate属性实际上并没有声明为弱引用,而是一个__unsafe_unretained引用,以便与非ARC版本的iOS向后兼容。因此,也许我需要编写
- (void)dealloc
{
_tableView.dataSource = nil;
_tableView.delegate = nil;
}
现在,如果我必须要重写dealloc方法,那么我是不是还需要设置_customView.delegate = nil
呢?因为它被我声明为一个弱引用,所以在MyViewController
销毁时应该自动设置为nil。
但另一方面,我并不是针对非ARC版本的iOS,也没有这个意图。所以也许我根本不需要重写dealloc方法?