从实践谈iOS生命周期

从实践谈iOS生命周期

个人感觉生命周期无论在Android,还是iOS都是很重要的概念,因为在每个声明周期的状态下我们可以做很多预加载或者处理的操作。因此在这里主要总结下ViewController和AppDelegate中的一些状态。

应用程序的状态

看下这个图:

  • Foreground :前台
  • Background :后台
  • Not running:应用程序并没有启动
  • Inactive :应用程序运行在前台但是没有接收到事件响应
  • Active :应用程序运行在前台接受到事件响应
  • Background :运行在后台并且执行代码
  • Suspended :运行在后台但是没有运行代码

APP启动

基本上每一次的状态改变都会调用一些delegate对象来响应当前的状态。就来介绍下这些delegate对象并且说明一些实际当中的使用

-(BOOL)application:(UIApplication *)application willFinishLaunchingWithOptions:(NSDictionary *)launchOptions{

NSLog(@"willFinishLaunchingWithOptions");

return YES;

}

willFinishLaunchingWithOptions就是应用程序在启动的时候的一个状态,就是页面将要显示的时候的一个状态。

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

// Override point for customization after application launch.

NSLog(@"didFinishLaunchingWithOptions");

return YES;

}

didFinishLaunchingWithOptions就是在应用程序在显示前最后一次的操作机会

可以看下验证:

既然是在app在显示app给用户之前执行的操作,理所当然我们可以在这里做一些基本的初始化的操作,但是应该是一些轻量级的初始话操作,否则会影响用户体验。举一些例子:

  • 我用代码写UI,没有使用StoryBoard,就会在这里配置下window
  • 还有就是例如你有一些Fabric之类的插件做数据分析的,AdMob广告之类的初始化其实都可以放在这里的。
  • 甚至是AFNetworking的startMonitor这些初始化操作都能放在这里

但是分析下,willFinishLaunchingWithOptions和didFinishLaunchingWithOptions描述上差不多,但是又有什么本质的区别呢?

个人感觉在使用上其实并没有太大的区别,但是本质的区别我觉得跟Android的onStart和onResume有一些类似,在Android中他们的区别是根据Activity是否可见这个角度说明的,其实就是一个准备前跟准备完成后的区别,willFinishLaunchingWithOptions是声明当前的进程已经启动但是还没有进入状态保存,那么didFinishLaunchingWithOptions就是声明所有基本的准备工作已经完成,可以开始启动了,因此刚才谈到的一些实际场景的应用基本上都是在didFinishLaunchingWithOptions做的。

再启动这里还有另一个状态,看下代码:

- (void)applicationDidBecomeActive:(UIApplication *)application {

NSLog(@"applicationDidBecomeActive");

}

整个的启动过程其实是这样的,app启动之后,状态由not running变换为inactive,接着调用上面提到的两个方法,接着就是由inactive切换到active状态,这个时候会调用applicationDidBecomeActive,这里就不演示了,感兴趣可以自己看看,因此,在锁屏,来回切换App都会调用applicationDidBecomeActive方法。

App发生中断

中断情况典型的可能就是有人打电话进来,这个时候就会进入inactive状态,准备进入后台,这里会调用

- (void)applicationWillResignActive:(UIApplication *)application {

NSLog(@"applicationWillResignActive");

}

实际应用中就是一些暂停操作:

  • 例如对视频的暂停操作
  • 对音乐的暂停操作
  • 游戏的话可能有的也需要暂停
  • 将一些不重要的任务都挂起,你要是还有下载任务的话,可以考虑结束它或者是暂停它,当然要是NSURLSession的话,如果我们下载的东西不大的话,可以考虑不管它

App从后台切回

- (void)applicationWillEnterForeground:(UIApplication *)application {

NSLog(@"applicationWillEnterForeground");

}

App将要从后台切回来,此时调用这个方法,在这里我们需要做的就是考虑你的应用需不需要更新啊,是否需要从server去拉数据呀。

基本上就可以考虑在这里做一些经常需要更新的操作,很多应用我觉得也是在这里上传时间戳文件跟远程server做数据对比,如果时间戳不一样,则拉去数据。

终止应用程序

iOS系统本身就存在系统内存回收的机制,就是当其他App启动的内存不足的时候去终止一些应用程序,也有可能是在后台上时间未响应被终止的。因此,系统在终止之前会调用

- (void)applicationWillTerminate:(UIApplication *)application {

[self saveContext];

}

目的就是为了保留一些重要的数据,方便下次启动后的恢复,达到一种让用户感觉我的应用永远运行在后台从来没被终止过的感觉。

ViewController的生命周期

这里就简单的概述下.

-(void)viewDidAppear:(BOOL)animated{

}

-(void)viewWillAppear:(BOOL)animated{

}

以上两个方法就是用来注册和移除通知,observer之类的,因为每次这个View出现,消息都会调用这两个方法,可以达防止内存泄露。

- (void)viewDidLoad {

[super viewDidLoad];

// Do any additional setup after loading the view, typically from a nib.

}

就是当前的vc初始化的时候,在这里可以配置自己的navi bar之类的。

结束

基本上就是这些吧,在这里简单的总结下,系统利用main run loop来管理事件循环,决定将事件交给系统哪些对象处理和如何处理。如果想要更深入的去了解这块,可以看看这个深入理解RunLoop

http://blog.ibireme.com/2015/05/18/runloop/

生命周期在我们的实践应用中使用的地方会很多,这里没有很深入的总结,因为自身的能力有限,如果大家有什么更好的,或者觉得这篇文章中有哪些地方需要更改或者添加,给我留言,欢迎指出缺点和错误。

时间: 2024-10-09 15:48:18

从实践谈iOS生命周期的相关文章

iOS生命周期 & 通知中心

笔记内容 学习笔记-段玉磊 Stanford course View Controller Lifecycle 这篇文是我记载Developing iOS 7 Apps公开课 第5课的笔记 UITextView Set its text and attributes via its NSMutableAttributedString 使用UITextView 要属性NSTextStorage类型 @property (nonatomic, readonly) NSTextStorage *tex

iOS 生命周期 -init、viewDidLoad、viewWillAppear、viewDidAppear、viewWillDisappear、viewDidDisappear 区别和用途

iOS视图控制对象生命周期-init.viewDidLoad.viewWillAppear.viewDidAppear.viewWillDisappear.viewDidDisappear的区别及用途 init-初始化程序 viewDidLoad-加载视图 viewWillAppear-UIViewController对象的视图即将加入窗口时调用: viewDidApper-UIViewController对象的视图已经加入到窗口时调用: viewWillDisappear-UIViewCont

浅谈UIViewController生命周期

UIViewController是IOS中顶层视图的载体和控制器,用户与程序界面的交互都是由UIViewController来控制的,UIViewController管理UIView的生命周期及资源的加载与释放. 我们创建一个简单的demo来测试一下其生命周期,新建两个ViewController,一个是A页面,一个是B页面.A页面有个按钮可以跳转到B页面,并且在每个ViewController的每个方法中都添加了NSLog来打印其状态.截取AViewController.m部分代码如下,  #

iOS生命周期-各状态详解

iOS的应用程序的生命周期,还有程序是运行在前台还是后台,应用程序各个状态的变换,这些对于开发者来说都是很重要的. iOS系统的资源是有限的,应用程序在前台和在后台的状态是不一样的.在后台时,程序会受到系统的很多限制,这样可以提高电池的使用和用户体验. //开发app,我们要遵循apple公司的一些指导原则,原则如下: 1.应用程序的状态 状态如下: Not running  未运行  程序没启动 Inactive   未激活   程序在前台运行,不过没有接收到事件.在没有事件处理情况下程序通常

angular2系列教程(五)Structural directives、再谈组件生命周期

今天,我们要讲的是structural directives和组件生命周期这两个知识点.structural directives顾名思义就是改变dom结构的指令.著名的内建结构指令有 ngIf, ngSwitch and ngFor. 例子 例子是我自己改写的,编写一个structural directives,然后通过这个指令实例化和注销组件,在此同时监视组件生命周期. 源代码 UnlessDirective 这个指令是官网示例中的指令. src/unless.directive.ts im

iOS 生命周期调用顺序

演示从ViewController到TextViewController的顺序 单个viewcontroller的顺序如下: 2015-08-08 11:32:01.601 text[2593:63988] TextViewController loadView 2015-08-08 11:32:01.602 text[2593:63988] TextViewController viewDidLoad 2015-08-08 11:32:01.603 text[2593:63988] TextV

再谈Activity生命周期

首先来幅很经典的图,看完之后再说话 1.启动一个新的Activity A,执行onCreate() -> onStart() -> onResume,此时该Activity获取焦点并且运行在前台. 2.当Activity A失去焦点但是仍然可见,也就是当我们重新启动一个新的Activity B,Activity B是透明的或者尺寸并不是全屏显示,这样我们还是可以看到底部的Activity A,但是它被Activity B覆盖或者部分覆盖,所以此时Activity A会执行onPause()方法

iOS开发——生命周期

为了处理好应用程序的挂起.暂停等情况下的数据保存,或对应添加所需处理,我们必须了解ios生命周期. 但是不要去背去记,做个实验就好. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{    // Override point for customization after application launch.    NSLog

iOS对UIViewController生命周期和属性方法的解析

目录[-] iOS对UIViewController生命周期和属性方法的解析 一.引言 二.UIViewController的生命周期 三.从storyBoard加载UIViewController实例的传值陷阱 四.UIViewController与StroyBoard的相关相互方法 1.ViewController直接在StoryBoard中进行跳转的传值 2.使用代码跳转Storyboard中的controller 五.UIViewController之间的一些从属关系 1.parentV