iOS应用生命周期

  作为应用程序的委托对象,AppDelegate类在应用生命周期的不同阶段会回调不同的方法。首先,让我们先了解一下iOS 应用的不同状态及它们彼此间的关系,见图1 。

图1 iOS应用状态图

  下面简要介绍一下iOS 应用的5种状态。
  ? Not Running(非运行状态)。应用没有运行或被系统终止。
  ? Inactive (前台非活动状态)。应用正在进入前台状态,但是还不能接受事件处理。
  ? Active (前台活动状态)。应用进入前台状态,能接受事件处理。
  ? Background(后台状态)。应用进入后台后,依然能够执行代码。如果有可执行的代码,就会执行代码,如果没有可执行的代码或者将可执行的代码执行完毕,应用会马上进入挂起状态。 
  ? Suspended(挂起状态)。处于挂起的应用进入一种“冷冻”状态,不能执行代码。如果系统内存不够,应用会被终止。 
  在应用状态跃迁的过程中,iOS 系统会回调AppDelegate中的一些方法,并且发送一些通知。实际上,在应用的生命周期中用到的方法和通知很多,我们选取了几个主要的方法和通知进行详细介绍,具体如表1所述。

表1 状态跃迁过程中应用回调的方法和本地通知

  为了便于观察应用程序的运行状态,我们为AppDelegate.m中的方法添加一些日志输出,具体代码如下:

@implementation AppDelegate  

- (BOOL)application:(UIApplication *)application
    didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
    NSLog(@"%@", @"application:didFinishLaunchingWithOptions:"); 

    return YES;
}
- (void)applicationWillResignActive:(UIApplication *)application
{
    NSLog(@"%@", @"applicationWillResignActive:");
}
- (void)applicationDidEnterBackground:(UIApplication *)application
{
    NSLog(@"%@", @"applicationDidEnterBackground:");
}
- (void)applicationWillEnterForeground:(UIApplication *)application
{
    NSLog(@"%@", @"applicationWillEnterForeground:");
}
- (void)applicationDidBecomeActive:(UIApplication *)application
{
    NSLog(@"%@", @"applicationDidBecomeActive:");
}
- (void)applicationWillTerminate:(UIApplication *)application
{
    NSLog(@"%@", @"applicationWillTerminate:");
}
@end

  为了让大家更直观地了解各状态与其相应的方法、通知间的关系,下面我们以几个应用场景为切入点进行系统的分析。

(一)非运行状态——应用启动场景

  场景描述:用户点击应用图标的时候,可能是第一次启动这个应用,也可能是应用终止后再次启动。该场景的状态跃迁过程见图2 ,共经历两个阶段3个状态:Not running →Inactive→Active。
  ? 在Not running→Inactive 阶段。调用application:didFinishLaunchingWithOptions:方法,发出UIApplicationDidFinishLaunchingNotification 通知。 
  ? 在Inactive →Active 阶段。调用 applicationDidBecomeActive: 方法,发出UIApplicationDidBecomeActiveNotification 通知。

图2 应用启动场景的状态跃迁过程

(二)点击Home键——应用退出场景

  场景描述:应用处于运行状态(即Active状态)时,点击Home键或者有其他的应用导致当前应用中断。该场景的状态跃迁过程可以分成两种情况:可以在后台运行或者挂起,不可以在后台运行或者挂起。根据产品属性文件(如HelloWorld-Info.plist)中的相关属性Application does not run in background 是与否可以控制这两种状态。如果采用文本编辑器打开HelloWorldInfo.plist文件该设置项对应的键是UIApplicationExitsOnSuspend。 

  状态跃迁的第一种情况:应用可以在后台运行或者挂起,该场景的状态跃迁过程见图3 ,共经历3 个阶段4个状态:Active → Inactive → Background→Suspended。

  ? 在Active→Inactive 阶段。调用 applicationWillResignActive:方法,发出UIApplicationWillResignActiveNotification 通知。 
  ? 在Inactive →Background阶段。应用从非活动状态进入到后台(不涉及我们要重点说明的方法和通知)。
  ? 在Background→Suspended 阶段。调用applicationDidEnterBackground:方法,发出UIApplicationDidEnterBackgroundNotification 通知。

               

                               图3 点击Home键应用退出场景

  状态跃迁的第二种情况:应用不可以在后台运行或者挂起,其状态跃迁情况见图4 ,共经历4个阶段5 个状态:Active  → Inactive  → Background→Suspended→Not running 。

  ? 在Active →Inactivd 阶段。应用由活动状态转为非活动状态(不涉及我们要重点说明的方法和通知)。
  ? 在Inactive →Background阶段。应用从非活动状态进入到后台(不涉及我们要重点说明的方法和通知)。
  ? 在Background→Suspended 阶段。调用applicationDidEnterBackground:方法, 发出UIApplicationDidEnterBackgroundNotification 通知。
  ? 在Suspended →Not running阶段。调用applicationWillTerminate:方法,发出UIApplicationWillTerminateNotification通知。

                      图4 点击Home键,应用退出场景

  iOS 在iOS 4之前不支持多任务,点击Home键时,应用会退出并中断;而在iOS 4之后(包括iOS 4),操作系统能够支持多任务处理,点击Home键应用会进入后台但不会中断(内存不够的情况除外)。
  应用在后台也可以进行部分处理工作,处理完成则进入挂起状态。

(三)挂起重新运行场景

  场景描述:挂起状态的应用重新运行。该场景的状态跃迁过程如图5 所示,共经历3 个阶段4 个状态:Suspended  → Background  → Inactive  → Active 。

                  图5 重新运行场景的状态跃迁过程

  ? Suspended→Background阶段。应用从挂起状态进入后台(不涉及我们讲述的这几个方法和通知)。
  ? Background→Inactive 阶段。调用applicationWillEnterForeground: 方法,发出UIApplicationWillEnterForegroundNotification通知。 
  ? Inactive →Active 阶段。调用applicationDidBecomeActive:方法,发出UIApplicationDidBecomeActiveNotification 通知。

(四)内存清除——应用终止场景

  场景描述:应用在后台处理完成时进入挂起状态(这是一种休眠状态),如果这时发出低内存警告,为了满足其他应用对内存的需要,该应用就会被清除内存从而终止运行,该场景的状态跃迁见图6 。

                      

                        图6 内存清除终止场景

  内存清除的时候应用终止运行。内存清除有两种情况,可能是系统强制清除内存,也可能是由使用者从任务栏中手动清除(即删掉应用)。内存清除后如果应用再次运行,上一次的运行状态不会被保存,相当于应用第一次运行。

  在内存清除场景下,应用不会调用任何方法,也不会发出任何通知。

时间: 2024-12-18 20:11:34

iOS应用生命周期的相关文章

IOS Application生命周期

应用程序的状态 Not running(未运行):程序没启动 Inactive(未激活):程序在前台运行,不过没有接收到事件.在没有事件处理情况下程序通常停留在这个状态 Active(激活):程序在前台运行而且接收到了事件.这也是前台的一个正常的模式 Backgroud(后台):序在后台而且能执行代码,大多数程序进入这个后台后会在在这个状态上停留一会.时间到之后会进入挂起状态(Suspended).有的程序经过特殊的请求后可以长期处于Backgroud状态 Suspended(挂起):程序在后台

图解ios程序生命周期

图解ios程序生命周期 应用程序启动后状态有Active.Inactive.Background.Suspended.Not running这5种状态,几种状态的转换见下图: 在AppDelegate中实现app状态变化时的回调函数,在 app状态发生变化时,系统会执行相应回调: - (BOOL)application:(UIApplication *)application willFinishLaunchingWithOptions:(NSDictionary *)launchOptions

IOS ViewController生命周期

ViewController ViewController是IOS开发中MVC模式中的C,ViewController是view的controller,ViewController的职责主要包括管理内部各个view的加载显示和卸载,同时负责与其他ViewController的通信和协调. 在IOS中,有两类ViewController,一类是显示内容的,比如UIViewController.UITableViewController等,同时还可以自定义继承自UIViewController的Vi

IOS的生命周期问题

开发Android必须得清楚Android生命周期才能很好的掌控程序的框架,让整个项目思路更加清晰流畅,因此IOS也是必须要了解IOS的生命周期 先从一个简单的实例来看看 AppDelegate.m文件里面的内容如下: // // AppDelegate.m // SwitchView // // Created by Pishum on 15/5/5. // Copyright (c) 2015年 Pishum. All rights reserved. // #import "AppDele

iOS视图生命周期与视图控制器关系

iOS中视图是一个应用的重要组成部分,功能的实现与其息息相关,而视图控制器控制着视图,其重要性在整个应用中不言而喻. 视图生命周期与视图控制器关系 以视图的5种状态为基础,我们来系统的了解一下视图控制器的生命周期.在视图不同的生命周期,视图控制器会回调不同的方法. viewDidLoad方法:视图控制器已被实例化,在视图被加载到内存中的时候调用该方法,这个时候视图并未出现.在该方法中通常进行的是对所控制的视图进行初始化处理. 视图可见前后会调用viewWillAppear:方法和viewDidA

iOS界面生命周期过程详解

开发过Android的人都知道,每一个Android界面就是一个Activity,而每一个Activity都会有自己的生命周期, 有一系列方法会控制Activity的生命周期,如:onCreate(),onStart(),onResume(),onDestroy()等等.在iOS中,也会有这样的流程控制.这篇博客先来讨论一个iOS应用的控制流程. 在新创建的一个程序中会有一个AppDelegate.swift文件,里面包含的一系列方法体现了iOS的控制流程.下面是系统自己生成的代码,我们来感受一

iOS程序生命周期 AppDelegate

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

【Xamarin 开发 IOS --IOS ViewController生命周期】

ViewController ViewController是IOS开发中MVC模式中的C,ViewController是view的controller,ViewController的职责主要包括管理内部各个view的加载显示和卸载,同时负责与其他ViewController的通信和协调. 在IOS中,有两类ViewController,一类是显示内容的,比如UIViewController.UITableViewController等,同时还可以自定义继承自UIViewController的Vi

iOS开发——生命周期

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