- loadView、viewDidLoad及viewDidUnlo
- loadView、viewDidLoad及viewDidUnlo
- loadView,viewDidLoad及viewDidUnlo
- loadView、viewDidLoad及viewDidUnlo
- loadView、viewDidLoad及viewDidUnlo
- loadView、viewDidLoad、viewDidUnlo
- loadView、viewDidLoad、viewDidUnlo
- loadView、viewDidLoad
- 二 loadView、viewDidLoad及viewDidUn
- 关于viewController的生命周期的分析
一, loadView和viewDidload
在控制器加载view的时候,系统默认做法:访问self.view如果view==nil就会调用loadView方法,所以会产生以下需要特别注意的地方:
#import "MyViewController.h"
#import "MyView.h"
@interface MyViewController ()
@end
@implementation MyViewController
//首先系统默认做法,访问self.view如果view==nil就会调用loadView方法
//系统底层view的get方法是通知loadView方法创建控制器的view.
//1.判断当前的控制器是否从StoryBoard加载的.如果是,从StoryBoad当中创建view.
//2.如果不是,还会判断当前控制器,是否有xib进行描述.如果有,就会从Xib里面创建View
//3.如果也不是xib来描述的,那么它就会给创建一个空的UIView.
/*
* 在开发当中一旦重写了loadView,需要自己创建View.
* 重写loadView一般用在:
* 1.当控制器的view一进来就是显示一个图片时
* 2.当控制器一进来就去加载一个网页时.
* 特别注意:loadView 重写时不调用[super loadView]容易访问到空view;
* 而访问self.view,会访问空的view,会导致死循环exc_bad_access(code = 2....)的错误
*/
//若假定不能从storyBoard和xib加载view,重写loadView如下:
-(void)loadView {
// [super loadView];
// NSLog(@"我执行了%s",__func__);
//特别注意:如果view为nil,调用self.view方法会造成死循环
// self.view = [[MyView alloc]initWithFrame:self.view.bounds];
//创建imageV
UIImageView *imageV = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"Default"]];
imageV.frame = [UIScreen mainScreen].bounds;
// 特别注意: 此处调用self.view会在view没赋值时候导致死循环
// imageV.frame = self.view.bounds;
// //如果一个控件它的父控件不能够接收事件,那么它里面的子控件都不能够接收事件.
imageV.userInteractionEnabled = YES;
//给view属性赋值
self.view = imageV;
}
//loadView是当第一次使用控制器View的调用.调用控制器view的get方法
//以下为模拟系统实现view方法的原理,注意如果view为空则会调用loadView方法加载view
//-(UIView *)view {
// if (_view == nil) {
// [self loadView];
// }
// return _view;
//}
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view from its nib.
NSLog(@"%@",self.view);
UIButton *btn = [UIButton buttonWithType:UIButtonTypeContactAdd];
btn.frame = CGRectMake(50, 100, 50, 50);
[self.view addSubview:btn];
}
二, viewDidUnload
1.什么时候被调用?
iOS设备的内存是极其有限的,如果应用程序占用的内存过多的话,系统就会对应用程序发出内存警告。UIViewController就会收到didReceiveMemoryWarning消息。didReceiveMemoryWarning方法的默认实现是:如果当前UIViewController的view不在应用程序的视图层次结构(View Hierarchy)中,即view的superview为nil的时候,就会将view释放,并且调用viewDidUnload方法
2.有什么作用?
上面说到,发出内存警告且view被释放的时候就会调用viewDidUnload方法,所以一般在释放资源,主要是释放界面元素相关的资源,将相关的实例都赋值为nil
[java] view plain copy
- (void)viewDidUnload {
[super viewDidUnload];
self.name = nil;
self.pwd = nil;
}
3.dealloc也是用来释放资源的,那跟viewDidUnload有什么关系?
当发出内存警告调用viewDidUnload方法时,只是释放了view,并没有释放UIViewController,所以并不会调用dealloc方法。即viewDidUnload和dealloc方法并没有任何关系,dealloc方法只会在UIViewController被释放的时候调用
三, 三个方法的关系:
1.第一次访问UIViewController的view时,view为nil,然后就会调用loadView方法创建view
2.view创建完毕后会调用viewDidLoad方法进行界面元素的初始化
3.当内存警告时,系统可能会释放UIViewController的view,将view赋值为nil,并且调用viewDidUnload方法
4.当再次访问UIViewController的view时,view已经在3中被赋值为nil,所以又会调用loadView方法重新创建view
5.view被重新创建完毕后,还是会调用viewDidLoad方法进行界面元素的初始化
网友评论