视图的属性的生命周期

来源:互联网 发布:新网站seo 编辑:程序博客网 时间:2024/06/06 14:09

只是一个简单的小知识点,昨天遇到的,今天记下来。


先说结论:
以下是正确的观点:

视图(或者准确的说是类)的属性,的释放是和视图的释放在同一时刻的,但是是否释放根据属性是否被其他对象持有所决定。

以下是错误观点:

视图的释放是一个同步阻塞的顺序,当某一个属性无法释放时,会导致视图本身无法释放。


以及这个点可能引起的坑:

视图的释放和视图的属性的释放不是同步的,如果设计不合理,会出现这样一种情况,视图释放了,但是视图里的东西,比如:数据(NSData、NSDictionary、NSArray)、图片(UIImage)无法释放。


然后说原理:

从引用计数的角度来讲,类本身是一个大的autoreleasepool,类释放时,会将其持有的所有属性的引用计数减1,而属性释放释放,则由其本身的引用计数决定。

以及强引用strong,弱引用weak

C的说法是:类的属性有两条线,一条是引用,相当于一个list里面有所有的属性的内存,可以随时调用。一条是持有,持有list里面的东西才会加入到自动释放池。
OC的说法:strong相当于说,会将该对象加入类的autoreleasepool,而弱引用不会


最后,show me your code
首先是将要销毁的视图NextVC:

头文件:

#import <UIKit/UIKit.h>@interface NextVC : UIViewController@property (nonatomic, strong) NSMutableDictionary *dict;@end

源文件:

#import "NextVC.h"@implementation NextVC- (void)viewWillAppear:(BOOL)animated {    self.view.backgroundColor = [UIColor whiteColor];}- (NSMutableDictionary *)dict {    if (_dict == nil) {        _dict = [[NSMutableDictionary alloc]init];    }    return  _dict;}- (void)dealloc{    NSLog(@"销毁了");}@end

然后是另一个视图ViewController:

#import "ViewController.h"#import "NextVC.h"@interface ViewController ()@property (nonatomic, strong) NSMutableArray *models;@end@implementation ViewController- (void)viewDidLoad {    [super viewDidLoad];    // Do any additional setup after loading the view, typically from a nib.    self.view.backgroundColor = [UIColor cyanColor];}- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {    NextVC *nextVC = [[NextVC alloc]init];    nextVC.dict[@"age"] = @(arc4random()%100);    [self.models addObject:nextVC.dict];    [self.navigationController pushViewController:nextVC animated:YES];    NSLog(@"%@", self.models);}- (NSMutableArray *)models {    if (_models == nil) {        _models = [[NSMutableArray alloc]init];    }    return _models;}@end

做的操作很简单,就是把nextVC的一个强引用的字典dict添加到ViewController的实例对象的一个数组里。
结果是,当需要销毁nextVC时,nextVC能够正常销毁,dict字典不会销毁。

0 0