iOS应用程序生命周期

iOS应用程序生命周期

App状态变化历史:

在iOS4之前的App时代,整个界面只允许一个App处于运行状态,而当某个App处于运行状态时意味着其他所有的App的活动都被终止并退出,无法接受任何事件.一个应用的状态转换只有运行、退出之间的变换.在iOS4之后的iPhone进入了多任务处理时代.也意味了当从一个应用切换到另一个应用时,系统不会马上将原来的应用终止退出,将其状态变成了suspend,而另一个应用的状态变成了running.

AppDelegate

运行一个App,应用程序会自动创建UIApplication单例对象,并被强引用(保证不会被销毁直到App退出),其UIApplicaiton实例的delegate属性被赋值为AppDelegate实例对象(其也是一个单例,也永远不会被释放直到该App退出).而AppDelegate对象有着一系列在程序启动时的跟踪状态变化,处理从其他应用跳转、启动到此应用,或者后台运行代码的方法.

AppDelegate做为App的根对象的主要功能:

1. 运行在启动时自己用来初始化应用的特点代码.
2. 响应App从启动,到后台,到前台,到退出时各个状态时的指定方法.
3. 负责处理接收推送通知或本地通知启动App的情况,处理手机低内存警告时的情况.
4. 负责处理应用程序的状态保存和恢复.
5. 响应由App处理的事件,而是指定控制器或视图.
6. 处理数据的存储.
应用程序的状态:
1. Not running    未运行     程序处于没启动状态
2. Inactive     未激活 程序在前台运行, 但是没有接收到任何事件, 没有事件处理的情况下程序通常停留在这个状态
3. Active           激活      程序在前台运行,并且接收到事件.
4. Background   程序在后台且能执行代码      大多数程序进入后台这个状态后会在这个状态停留一会, 然后进入Suspended(挂起状态), 而有的程序经过特殊的请求可以长期处于Background状态.   
5. Suspended         挂起    程序在后台不能执行代码, 系统会自动将程序变成这个状态且不会发通知. 当挂起时, 程序还是停留在内存中的, 当系统内存不足时,系统就会把挂起的程序清除掉, 为前台程序提供更多内存
程序状态切换图:
各个程序运行状态 代理的回调方法
- (void)applicationWillResignActive:(UIApplication *)application {
    // 当应用从activite状态跳转到inactive状态时, 调用该方法. 许多的暂时打断App操作都会触发该方法. (诸如: 有电话打进来时, 收到消息时, 支持多任务的iPad进行侧边栏滑动时等情况) 或者当用户停止App并且让App进入后台状态时(Inactive状态)(如按Home键回到键入主界面,划出通知栏或者设置)
    // 可以通过该方法停止进行中的任务, 让定时器失效, 进制图形渲染回调方法. 游戏类App 用该方法停止游戏
}


- (void)applicationDidEnterBackground:(UIApplication *)application {
    // 该方法可以用来释放共享的资源, 保存数据, 停止定时器, 保存App当前状态信息防止App在之后被销毁掉时, 丢失了信息
    // 如果你的App支持后台运行, 该方法将会在用户触发停止App操作时(如按Home键), 取代 applicationWillTerminate 
}


- (void)applicationWillEnterForeground:(UIApplication *)application {
    // 在App从background状态跳转到active状态时该方法被执行, 在这个方法中你可以撤销任何在App进入background状态时所做的改变.
}


- (void)applicationDidBecomeActive:(UIApplication *)application {
    // 重启那些在App处于inactive状态时被停止的任务(或那些还未启动的), 如果App之前处于background 状态,  通常要刷新UI
}


- (void)applicationWillTerminate:(UIApplication *)application {
    // App将要终止时被调用, 如果有必要可以保持一些数据, 同时也要看看方法 applicationDidEnterBackground:
}

加载应用程序进入前台:
加载应用程序进入后台:
应用返回前台运行:
应用转到后台运行:

当一个基于警告式的中断发生时,比如有电话打进来了,这是程序会临时进入inactive状态,这用户可以选择如何处理这个中断

响应中断:
Main Run Loop 处理时间的架构图:
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容