首页 > 代码库 > viewDidLoad 和 didReceiveMemoryWarning
viewDidLoad 和 didReceiveMemoryWarning
在我们创建一个新的.h 和 .m文件时,我们会看到.h:
@implementation TestViewController- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view.}- (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated.}
我们来看一下注释中的意思:
Do any additional setup after loading the view. Dispose of any resources that can be recreated.
做任何额外的设置后加载视图。 处理任何可以被重新创建的资源。
API文档中如是解释
viewDidLoad:调用此方法后,视图控制器已加载视图层次到内存中。调用此方法无论从nib文件或加载视图层次loadView方法中以编程方式创建。你通常覆盖这个方法执行额外的初始化视图从nib文件被加载。
didReceiveMemoryWarning:发送给视图控制器当应用程序接收到一个内存警告。应用程序不会直接调用这个方法。相反,当系统调用此方法确定可用内存的数量很低。你可以重写此方法释放任何额外的内存使用的视图控制器。如果你这样做了,您的实现的方法必须调用实现。
(loadView/nib文件)来加载view到内存 ——>viewDidLoad函数进一步初始化这些view ——>内存不足时,调用viewDidUnload函数释放views
—->当需要使用view时有回到第一步
iPhone下每个app可用的内存是被限制的,如果一个app使用的内存超过20M,则系统会向该app发送Memory Warning消息。收到此消息后,app必须正确处理,否则可能出错或者出现内存泄露。
当收到内存警告时,如果viewcontroller未显示(在后台),会执行didReceiveMemoryWarning -> viewDidUnLoad;
如果viewcontroller当前正在显示(在前台),则只执行didReceiveMemoryWarning。
当重新显示该viewController时,执行过viewDidUnLoad的viewcontroller(即原来在后台)会重新调用loadview -> viewDidLoad。
viewDidLoad 和 didReceiveMemoryWarning