我们第一次打开Xcode的iOS应用模版时,首先会让我们去关注的是应用的主函数,也就是一个程序的入口。工程里的主函数main.m就是这个样子的
#import <UIKit/UIKit.h>#import "AppDelegate.h"int main(int argc, char * argv[]) {
@autoreleasepool {
return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
}
}
一看~这个主函数好简介啊,只用了一个函数,就建立起了我们的应用。
点击进入查看官方文档,可以发现其中的前两个参数和我们熟悉的C语言主函数的入口的参数相同,如果学过C应该很容易理解。所以让我们来看看后面两个参数。第三个参数大多是nil
,它的类型是NSString *
,代表应用程序单例UIApplication
的名字,如果填入nil
就代表是模板给我们创建好的该对象。后面一个是应用程序代理,这里用到了iOS常用的委托代理的模式。用一个UIResponder
类的实例AppDelegate
作为这个应用的委托对象。虽然官方文档里这个函数的有返回值int但是这个函数却不会返回东西。原因就在于iOS APP的一个运行机制。
可以把一个APP想象成一个运行时不会终止,一直等待事件
发生的循环体,叫做The Main Run Loop
。(事件包括两类:一类是对屏幕的点击,一类是摇动或按耳机键等等。)
So,在任何时间你的APP只会处于下面这几个状态:
状态 | 界面是否可见 | 是否接收事件 | 是否能执行代码 |
---|---|---|---|
未运行 Not running | 否 | 否 | 否 |
激活 Active | 是 | 是 | 是 |
未激活 Inactive | 大部分 | 否 | 是 |
后台运行 Background | 否 | 否 | 是 |
挂起 Suspended | 否 | 否 | 否 |
相应的会触发AppDelegate.m
中的以下方法(这些方法在UIApplicationDelegate协议中):PS:身边有电脑的童鞋,也可以随意打开一个项目,在以下方法中加入这句代码NSLog(@"%@", NSStringFromSelector(_cmd));
然后在调用这个方法的时候就会在控制台打印出该方法的名字niao > ~ <
1. 未运行 Not running -> 激活 Active
- (BOOL)application:(UIApplication *)application willFinishLaunchingWithOptions:(NSDictionary *)launchOptions{
NSLog(@"%@", NSStringFromSelector(_cmd)); retrun YES;
}
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
NSLog(@"%@", NSStringFromSelector(_cmd)); // Override point for customization after application launch. return YES;
}
- (void)applicationDidBecomeActive:(UIApplication *)application{
NSLog(@"%@", NSStringFromSelector(_cmd));
// 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.
}
2.激活 Active -> 未激活 Inactive (eg. 当按下home键 或 接入电话时触发)
- (void)applicationWillResignActive:(UIApplication *)application{ NSLog(@"%@", NSStringFromSelector(_cmd));
}
3.未激活 Inactive -> 后台运行 Background
- (void)applicationDidEnterBackground:(UIApplication *)application{
NSLog(@"%@", NSStringFromSelector(_cmd));
}
4.后台运行 Background -> 挂起 Suspended ( 系统在APP进入后台状态大概 5秒 后自动触发状态改变)
5.挂起 Suspended -> 激活 Active(eg.重新点击图标时触发)
- (void)applicationWillEnterForeground:(UIApplication *)application{
NSLog(@"%@", NSStringFromSelector(_cmd));
// 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.
}
6.挂起 Suspended -> 未运行 Not running(退出APP时调用,可以在这里保存数据)
- (void)applicationWillTerminate:(UIApplication *)application{
NSLog(@"%@", NSStringFromSelector(_cmd));
//Save data if appropriate.
}
结(fei)语(hua):
1.UIApplicationDelegate协议中还不止这8个方法,但是列出来的这个几个用得比较多也比较典型。有兴趣的可以查阅UIApplicationDelegate协议官方文档。
2.第一次写简书,好累啊T—T
但是如果能给各位看官提供到一点点帮助,也就有了价值。
从写的过程中也收获不少吧~以后每周都坚持写一点,欢迎大家关注!
相互学习,共同进步。