ios - 程序启动原理&UIApplication
UIApplicationMain
main函数中执行了一个UIApplicationMain这个函数
int UIApplicationMain(int argc, char *argv[], NSString *principalClassName, NSString *delegateClassName);
argc、argv:直接传递给UIApplicationMain进行相关处理即可
principalClassName:指定应用程序类名(app的象征),该类必须是UIApplication(或子类)。如果为nil,则用UIApplication类作为默认值
delegateClassName:指定应用程序的代理类,该类必须遵守UIApplicationDelegate协议
UIApplicationMain函数会根据principalClassName创建 UIApplication对象,根据delegateClassName创建一个delegate对象,并将该delegate对象赋值给 UIApplication对象中的delegate属性
接着会建立应用程序的Main Runloop(事件循环),进行事件的处理(首先会在程序完毕后调用delegate对象的application:didFinishLaunchingWithOptions:方法)
#import <UIKit/UIKit.h> #import "DHAppDelegate.h" int main(int argc, char * argv[]) { @autoreleasepool { //return UIApplicationMain(argc, argv, nil, NSStringFromClass([DHAppDelegate class])); //return UIApplicationMain(argc, argv, nil, @"DHAppDelegate"); //return UIApplicationMain(argc, argv, @"UIApplication", @"DHAppDelegate"); return UIApplicationMain(argc, argv, NSStringFromClass([UIApplication class]), NSStringFromClass([DHAppDelegate class])); } }
ios程序启动原理

UIApplication
UIApplication对象是应用程序的象征
每一个应用都由自己的UIApplication对象,而且是单例的,
通过[UIApplication shareApplication]可以获得这个单例对象,
一个ios程序启动后创建的第一个对象就是UIApplication对象
UIApplication的常用属性:
- 设置应用程序图标右上角的红色提醒数字
@property(nonatomic) NSInteger applicationIconBadgeNumber;
- 设置联网指示器的可见性
@property(nonatomic,getter=isNetworkActivityIndicatorVisible) BOOL networkActivityIndicatorVisible;
- 从iOS7开始,系统提供了2种管理状态栏的方式
- 通过UIViewController管理(每一个UIViewController都可以拥有自己不同的状态栏)
- 通过UIApplication管理(一个应用程序的状态栏都由它统一管理)
- 在iOS7中,默认情况下,状态栏都是由UIViewController管理的,UIViewController实现下列方法就可以轻松管理状态栏的可见性和样式
- 状态栏的样式
- (UIStatusBarStyle)preferredStatusBarStyle;
- 状态栏的可见性
- (BOOL)prefersStatusBarHidden;
- 如果想利用UIApplication来管理状态栏,首先得修改Info.plist的设置
- UIApplication有个功能十分强大的openURL:方法
-
//通过sharedApplication获取该程序的UIApplication对象 UIApplication *app=[UIApplication sharedApplication]; app.applicationIconBadgeNumber=123; //设置指示器的联网动画 app.networkActivityIndicatorVisible=YES; //设置状态栏的样式 //app.statusBarStyle=UIStatusBarStyleDefault;//默认(黑色) //设置为白色+动画效果 [app setStatusBarStyle:UIStatusBarStyleLightContent animated:YES]; //设置状态栏是否隐藏 app.statusBarHidden=YES; //设置状态栏是否隐藏+动画效果 [app setStatusBarHidden:YES withAnimation:UIStatusBarAnimationFade];
-(BOOL)openURL:(NSURL*)url;
- openURL:方法的部分功能有
- 打电话
UIApplication *app = [UIApplication sharedApplication];
[app openURL:[NSURL URLWithString:@"tel://10086"]];
- 发短信
[app openURL:[NSURL URLWithString:@"sms://10086"]];
- 发邮件
[app openURL:[NSURL URLWithString:@"mailto://12345@qq.com"]];
- 打开一个网页资源
[app openURL:[NSURL URLWithString:@"http://ios.itcast.cn"]];
打开其他app程序#import "DHAppDelegate.h" @implementation DHAppDelegate // 当应用程序启动完毕的时候就会调用(系统自动调用) - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { NSLog(@"didFinishLaunchingWithOptions"); return YES; } // 即将失去活动状态的时候调用(失去焦点, 不可交互) - (void)applicationWillResignActive:(UIApplication *)application { NSLog(@"ResignActive"); } // 重新获取焦点(能够和用户交互) - (void)applicationDidBecomeActive:(UIApplication *)application { NSLog(@"BecomeActive"); } // 应用程序进入后台的时候调用 // 一般在该方法中保存应用程序的数据, 以及状态 - (void)applicationDidEnterBackground:(UIApplication *)application { NSLog(@"Background"); } // 应用程序即将进入前台的时候调用 // 一般在该方法中恢复应用程序的数据,以及状态 - (void)applicationWillEnterForeground:(UIApplication *)application { NSLog(@"Foreground"); } // 应用程序即将被销毁的时候会调用该方法 // 注意:如果应用程序处于挂起状态的时候无法调用该方法 - (void)applicationWillTerminate:(UIApplication *)application { } // 应用程序接收到内存警告的时候就会调用 // 一般在该方法中释放掉不需要的内存 - (void)applicationDidReceiveMemoryWarning:(UIApplication *)application { NSLog(@"MemoryWarning"); } @end
didFinishLaunchingWithOptions参数launchOptions内容
说明:当应用程序启动时执行,应用程序启动入口。只在应用程序启动时执行一次。application参数用来获取应用程序的状态、变量等,值得注意的是字典参数:(NSDictionary *)launchOptions,该参数存储程序启动的原因。
若用户直接启动,lauchOptions内无数据;
若由其他应用程序通过openURL:启动,则UIApplicationLaunchOptionsURLKey对应的对象为启动 URL(NSURL),
若由本地通知启动,则UIApplicationLaunchOptionsLocalNotificationKey对应的是为启动应用程序的的本地通知对象(UILocalNotification);
若由远程通知启动,则UIApplicationLaunchOptionsRemoteNotificationKey对应的是启动应用程序的的远程通知信息userInfo(NSDictionary);
其他key还有UIApplicationLaunchOptionsAnnotationKey,UIApplicationLaunchOptionsLocationKey,UIApplicationLaunchOptionsNewsstandDownloadsKey。
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{ NSURL *url = [launchOptions objectForKey:UIApplicationLaunchOptionsURLKey]; if(url) { } NSString *bundleId = [launchOptions objectForKey:UIApplicationLaunchOptionsSourceApplicationKey]; if(bundleId){} UILocalNotification * localNotify = [launchOptions objectForKey:UIApplicationLaunchOptionsLocalNotificationKey]; if(localNotify) { } NSDictionary * userInfo = [launchOptions objectForKey:UIApplicationLaunchOptionsRemoteNotificationKey]; if(userInfo) { } } 应用 /** * 跳转支付宝app支付时,app被kill,支付完成后,从支付宝app跳转app,return NO 不调用application: openURL:sourceApplication:annotation:(返回app首页) */ if (launchOptions) { NSString *appIDF = [launchOptionsobjectForKey:UIApplicationLaunchOptionsSourceApplicationKey]; if (appIDF && [appIDFisEqualToString:@"com.alipay.iphoneclient"]) { returnNO; } } #pragma mark--外部应用跳转到app的url处理 - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation { NSString *urlStr = [urlabsoluteString]; // 支付宝app进app if(sourceApplication && [sourceApplicationisEqualToString:@"com.alipay.iphoneclient"]){ [[AlipaySDKdefaultService] processOrderWithPaymentResult:urlstandbyCallback:^(NSDictionary *resultDic) { NSDictionary *dict = @{ALIPayDidCompleteURLKey:urlStr}; [[NSNotificationCenterdefaultCenter ] postNotificationName:ALIPayFromZFBDidCompleteNotificationobject:resultDic userInfo:dict]; }]; } returnYES; } //在支付类初始化方法 [[NSNotificationCenterdefaultCenter] addObserver:selfselector:@selector(processAliPayResult:)name:ALIPayFromZFBDidComple]
浙公网安备 33010602011771号