iOS APP启动流程
做ios也有一段时间了,但是app的整个的启动流程还似懂非懂,看了许多的博客和资料,在这里写篇博客权当总结笔记
在开始之前我们先看两张启动流程图
图一
<center>xcode4.2的启动示意图,不使用storyboarding</center>
图二
<br /><br />
从上面两张图我们可以看出,也是从main()函数开始,iOS的面函数比较简单就几行代码,只是调用
UIApplicationMain
函数 ,这个函数如下
int main(int argc, char * argv[]) {
@autoreleasepool {
return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
}
}
我们先来看一下UIApplicationMain
的这几个参数:
- argc 表示参数个数
- argv 表示函数参数的数组
- 是UIApplication类名或者是其子类名,如果是nil,则就默认使用UIApplication类名
- 是协议UIApplicationDelegate的实例化对象名,如果是nil,则从main nib文件中加载委托对象。这个对象就是UIApplication对象监听到系统变化的时候通知其执行的相应方法
此函数会创建一个UIApplication对象,并根据第四个参数创建一个delegate对象,然后将此delegate对象赋值给UIApplication对象的delegate属性。
接着会建立应用程序的Main Runloop
循环,调用UIApplicationDelegate中的函数进行事件处理
UIApplication
UiApplication代表一个应用程序,每一个应用程序都有一个UIApplication全局对象,而且这个对象是单例的,我们在程序中可以通过[UIApplication sharedApplication]
获得这个对象,进行一些应用级的操作。UIApplication是应用程序的开始,它维护了一个在本应用程序中打开的Window列表,负责初始化显示UIWindow,并负责加载应用程序的第一个UIView到UIWindow窗口中,在随后的操作中,我们也可以更换UIWindow窗口的显示内容。此外,UIApplication还被赋予一个代理对象,在实际编程中,我们一般并不直接与UIApplication打交道,而是和其代理对象UIApplicationDelegate
打交道,UIApplication负责监听接收事件,而由UIApplicationDelegate决定应用程序如何去响应这些事件(生命周期:程序启动和关闭,系统事件:来电、记事项警告)等等。
UIApplicationDelegate
所有的移动操作系统都有个致命的缺点:app很容易受到打扰.比如一个来电或者锁屏会导致app进入后台甚至被终止;还有很多其他类似的情况会导致app受到干扰,在app受到干扰时,会产生一些系统事件,这时UIApplication会通知它的delegate对象,让delegate来处理这些系统事件.由图二我们可以看到代理类可以处理许多事件
1.程序加载完毕
2.程序获取焦点
3.程序进入后台
4.程序失去焦点
5.程序从后台回到前台
6.内存不足警告
7.程序即将退出
</br>
程序中的AppDelegate.m都有相关的对应函数
#import "AppDelegate.h"
@interface AppDelegate ()
@end
@implementation AppDelegate
// 当应用程序启动完毕的时候就会调用(系统自动调用)
-(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
//Override point for customization after application launch.
return YES;
}
// 即将失去活动状态的时候调用(失去焦点, 不可交互)
-(void)applicationWillResignActive:(UIApplication *)application {
}
//应用程序进入后台的时候调用
// 一般在该方法中保存应用程序的数据, 以及状态
-(void)applicationDidEnterBackground:(UIApplication *)application {
// Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.
// If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
}
// 应用程序即将进入前台的时候调用
// 一般在该方法中恢复应用程序的数据,以及状态
- (void)applicationWillEnterForeground:(UIApplication *)application {
// Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background.
}
//重新获取焦点(能够和用户交互)
- (void)applicationDidBecomeActive:(UIApplication *)application {
// Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
}
// 应用程序即将被销毁的时候会调用该方法
// 注意:如果应用程序处于挂起状态的时候无法调用该方法
- (void)applicationWillTerminate:(UIApplication *)application {
// Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:
}
<strong>讲到这里我们可以看出一个APP的完整的启动流程</strong>:
1.main函数
2.执行UIApplicationMain函数
1.创建UIApplication对象
2.创建UIApplicationDelegate对象并复制
3.读取配置文件info.plist,设置程序启动的一些属性,(关于info.plist的内容我们下篇在讲解)
4.创建应用程序的Main Runloop
循环
3.UIApplicationDelegate对象开始处理监听到的事件
1.程序启动成功之后,首先调用<code>application:didFinishLaunchingWithOptions:</code>方法,
如果info.plist文件中配置了启动storyboard文件名,则加载storyboard文件。
如果没有配置,则根据代码来创建UIWindow--->UIWindow的rootViewController-->显示
</br>
-(BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
//所要显示的视图控件
LJTViewControler *LJTVC = [[LJTViewController alloc] init];
self.window.rootViewController=LJTVC;
[self.window makeKeyAndVisible];
return YES;
}