UIViewController各方法的调用顺序

来源:互联网 发布:网络推广的目的和意义 编辑:程序博客网 时间:2024/06/05 07:53

(1)init方法

在init方法中实例化必要的对象(遵从LazyLoad思想),init方法中初始化ViewController本身

     (2)- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil

      如果代码中有重写此方法,调用init方法时会默认调用这个方法。如果该方法中没有对self.view添加子视图,则调用顺序为该方法->控制器的属性设置方法->viewdidload。

但是!!!如果在该方法中为self.view添加了子视图,则调用[self.view addSubview:whiteView]的地方会马上去调用viewdidload方法,把viewdidload运行完,再回来继续执行- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil方法的代码。

当控制器被initWithNibName:初始化并加入到导航控制器的栈中时,它不会加载nib文件,直到nib文件被实际显示。因此控制器在nib文件中定 义的内容,例如label,可能还没有实例化。此时label可能只是一个nil指针,需要额外使用代码中实现的属性来存储信息。

(3)loadView方法

      无论XIB还是代码创建都会调用loadView方法,

      如果视图控制器不是通过nib文件创建的,必须重写该方法,给self.view赋值

如果使用IB维护views,必须不能重写该方法,否则ib定制的视图会被覆盖。

(4)viewDidLoad方法

无论XIB还是代码创建都会调用loadView方法,重写该方法以进一步定制view。在iPhone OS 3.0及之后的版本中,还应该重载重写viewDidUnload来释放对view的任何索引。

(5)viewDidUnload方法

当系统内存吃紧的时候会调用该方法

内存吃紧时,在iPhone OS 3.0之前didReceiveMemoryWarning是释放无用内存的唯一方式,但是OS 3.0以后viewDidUnload方法是更好的方式。

在该方法中将所有IBOutlet(无论是property还是实例变量)置为nil(系统release view时已经将其release掉了)

在该方法中释放其他与view有关的对象、其他在运行时创建(但非系统必须)的对象、在viewDidLoad中被创建的对象、缓存数据 等 release对象后,将对象置为nil(IBOutlet只需要将其置为nil,系统release view时已经将其release掉了)

viewDidUnload中被release的对象必须是很容易被重新创建的对象(比如在viewDidLoad或其他方法中创建的对象),不要release用户数据或其他很难被重新创建的对象

(6)didReceiveMemoryWarning

从iOS3.0开始,不需要重载这个函数,把释放内存的代码放到viewDidUnload中去。

这个函数的默认实现是:检查controller是否可以安全地释放它的view属性,如果view可以被释放,那么这个函数释放view并调用viewDidUnload。

你可以重写这个函数来释放controller中使用的其他内存。但要记得调用这个函数的super方法释放view。

(7)dealloc方法

viewDidUnload和dealloc方法没有关联,dealloc还是继续做它该做的事情。当一个对象的retain值为0时,就会调用它的方法dealloc。




0 0
原创粉丝点击