application:didFinishLaunchingWithOptions:詳解

由于剛剛開始學(xué)習(xí)接觸IOS 星星散散的記一些隨筆,會比較散亂...


IOS程序調(diào)用時總會調(diào)用

application:didFinishLaunchingWithOptions

Launch options為NSDictionary類型的對象 ?里面保存了程序啟動的原因

1.直接啟動: LauchOptions內(nèi)無數(shù)據(jù)

2.其他應(yīng)用程序通過OpenURL:啟動,UIApplicationLauchOptionsURLkey對應(yīng)的對象為啟動URL(NSURL).UIApplicationLauchOptionsSourceApplicationKey對應(yīng)啟動的源應(yīng)用程序的bundle ID(NSString);

3.若遠(yuǎn)程通知啟動,則UIApplicationLauchOptionsRemoteNotificationKey對應(yīng)的是啟動應(yīng)用程序遠(yuǎn)程通知信息UserInfo(NSDictionary);

4.若由本地通知啟動,則UIApplicationLauchOptionsLocalNotificationKey對應(yīng)的是為啟動應(yīng)用程序的本地通知對象(UILocalNotification);

5.其他Key還有

UIApplicationLaunchOptionsAnnotationKey;

UIApplicationLaunchOptionsLocationKey;

UIApplicationLaunchOptionsNewsstandDownloadsKey;

IOS中的AppDelegate.m/h文件很重要,它對Application的整個生命周期進(jìn)行管理。


Application詳解

IOS 中的 AppDelegate.m/h 文件是很重要的呢,因?yàn)樗菍?Application 的整個生命周期進(jìn)行管理的。

先明白,每個iPhone應(yīng)用程序都有一個UIApplication,UIApplication是iPhone應(yīng)用程序的開始并且負(fù)責(zé)初始化并顯 示 UIWindow,并負(fù)責(zé)加載應(yīng)用程序的第一個UIView到UIWindow窗體中。UIApplication的另一個任務(wù)是幫助管理應(yīng)用程序的 生命 周期,而UIApplication通過一個名字為UIApplicationDelegate的代理類來履行這個任務(wù)。盡管 UIApplication 會負(fù)責(zé)接收事件,而UIApplicationDelegate則決定應(yīng)用程序如何去響應(yīng)這些事 件,UIApplicationDelegate可以處理 的事件包括應(yīng)用程序的生命周期事件(比如程序啟動和關(guān)閉)、系統(tǒng)事件(比如來電、記事項(xiàng)警 告),本文會介紹如何加載應(yīng)用程序的UIView到 UIWindow以及如何利用UIApplicationDelegate處理系統(tǒng)事件。

通 常對于UIApplication讀者是沒必要修改它的,只需要知道UIApplication接收系統(tǒng)事件即可,而如何編寫代碼來處理這些系統(tǒng)事件 則 是程序員的工作。處理系統(tǒng)事件需要編寫一個繼承自UIApplicationDelegate接口的類,而 UIApplicationDelegate接 口提供生命周期函數(shù)來處理應(yīng)用程序以及應(yīng)用程序的系統(tǒng)事件,這些生命周期函數(shù)如下表所示:

1、- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions

{

NSLog(@"當(dāng)程序載入后執(zhí)行");

}

說明:當(dāng)程序載入后執(zhí)行,應(yīng)用程序啟動入口。只在應(yīng)用程序啟動時執(zhí)行一次。也就是說在應(yīng)用程序啟動后,要執(zhí)行的委托調(diào)用。application參數(shù)用來獲取應(yīng)用程序的狀態(tài)、變量等,值得注意的是字典參數(shù):(NSDictionary *)launchOptions,該參數(shù)存儲程序啟動的原因。

若用戶直接啟動,lauchOptions內(nèi)無數(shù)據(jù);

若由其他應(yīng)用程序通過openURL:啟動,則UIApplicationLaunchOptionsURLKey對應(yīng)的對象為啟動 URL(NSURL),UIApplicationLaunchOptionsSourceApplicationKey對應(yīng)啟動的源應(yīng)用程序的 bundle ID (NSString);

若由本地通知啟動,則UIApplicationLaunchOptionsLocalNotificationKey對應(yīng)的是為啟動應(yīng)用程序的的本地通知對象(UILocalNotification);

若由遠(yuǎn)程通知啟動,則UIApplicationLaunchOptionsRemoteNotificationKey對應(yīng)的是啟動應(yīng)用程序的的遠(yuǎn)程通知信息userInfo(NSDictionary);

其他key還有UIApplicationLaunchOptionsAnnotationKey,UIApplicationLaunchOptionsLocationKey,

UIApplicationLaunchOptionsNewsstandDownloadsKey。

如果要在啟動時,做出一些區(qū)分,那就需要在下面的代碼做處理。比如:應(yīng)用可以被某個其它應(yīng)用調(diào)起(作為該應(yīng)用的子應(yīng)用),要實(shí)現(xiàn)單點(diǎn)登錄,那就需要在啟動代碼的地方做出合理的驗(yàn)證,并跳過登錄。

例子:

- (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)

{

}

}

2、-? (void)applicationWillResignActive:(UIApplication *)application

{

NSLog(@"應(yīng)用程序?qū)⒁M(jìn)入非活動狀態(tài),即將進(jìn)入后臺");

}

在應(yīng)用程序?qū)⒁苫顒訝顟B(tài)切換到非活動狀態(tài)時候,要執(zhí)行的委托調(diào)用,如 按下 home 按鈕,返回主屏幕,或全屏之間切換應(yīng)用程序等。

說明:當(dāng)應(yīng)用程序?qū)⒁M(jìn)入非活動狀態(tài)時執(zhí)行,在此期間,應(yīng)用程序不接收消息或事件,比如來電話了。

3、- (void)applicationDidEnterBackground:(UIApplication *)application

{

NSLog(@"如果應(yīng)用程序支持后臺運(yùn)行,則應(yīng)用程序已經(jīng)進(jìn)入后臺運(yùn)行");

}

說明:當(dāng)程序被推送到后臺的時候調(diào)用。所以要設(shè)置后臺繼續(xù)運(yùn)行,則在這個函數(shù)里面設(shè)置即可

4、-? (void)applicationWillEnterForeground:(UIApplication *)application

{

NSLog(@"應(yīng)用程序?qū)⒁M(jìn)入活動狀態(tài),即將進(jìn)入前臺運(yùn)行");

}

說明:當(dāng)程序從后臺將要重新回到前臺時候調(diào)用,這個剛好跟上面的那個方法相反。

5、- (void)applicationDidBecomeActive:(UIApplication *)application

{

NSLog(@"應(yīng)用程序已進(jìn)入前臺,處于活動狀態(tài)");

}

說明:當(dāng)應(yīng)用程序進(jìn)入活動狀態(tài)時執(zhí)行,這個剛好跟上面那個方法相反 。

6、-? (void)applicationWillTerminate:(UIApplication *)application

{

NSLog(@"應(yīng)用程序?qū)⒁顺觯ǔS糜诒4鏀?shù)據(jù)和一些退出前的清理工作");

}

說明:當(dāng)程序?qū)⒁顺鍪潜徽{(diào)用,通常是用來保存數(shù)據(jù)和一些退出前的清理工作。這個需要要設(shè)置UIApplicationExitsOnSuspend的鍵值。

7、-? (void)applicationDidReceiveMemoryWarning:(UIApplication *)application

{

NSLog(@"系統(tǒng)內(nèi)存不足,需要進(jìn)行清理工作");

}

說明:iPhone設(shè)備只有有限的內(nèi)存,如果為應(yīng)用程序分配了太多內(nèi)存操作系統(tǒng)會終止應(yīng)用程序的運(yùn)行,在終止前會執(zhí)行這個方法,通??梢栽谶@里進(jìn)行內(nèi)存清理工作防止程序被終止。

8、-(void)applicationSignificantTimeChange:(UIApplication *)application

{

NSLog(@"當(dāng)系統(tǒng)時間發(fā)生改變時執(zhí)行");

}

說明:當(dāng)系統(tǒng)時間發(fā)生改變時執(zhí)行

9、-? (void)application:(UIApplication)application? willChangeStatusBarFrame:(CGRect)newStatusBarFrame

{

NSLog(@"StatusBar框?qū)⒁兓?);

}

說明:當(dāng)StatusBar框?qū)⒁兓瘯r執(zhí)行

10、-? (void)application:(UIApplication*)application willChangeStatusBarOrientation:

(UIInterfaceOrientation)newStatusBarOrientation duration:(NSTimeInterval)duration

{

}

說明:當(dāng)StatusBar框方向?qū)⒁兓瘯r執(zhí)行

11、- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url

{

}

說明:當(dāng)通過url執(zhí)行

12、-? (void)application:(UIApplication*)application? didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation

{

}

說明:當(dāng)StatusBar框方向變化完成后執(zhí)行

13、-? (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame

{

}

說明:當(dāng)StatusBar框變化完成后執(zhí)行

另外還有一些協(xié)議方法需要知道:

Handling Remote Notifications? (處理遠(yuǎn)程消息)

-(void) application:(UIApplication *) applicationdidReceiveRemoteNotification:(NSDictonary *) userinfo

說明:當(dāng)一個運(yùn)行著的應(yīng)用程序收到一個遠(yuǎn)程的通知 發(fā)送到委托去...

-(void) application:(UIApplication *) applicationdidRegisterForRemoteNotificationsWithDeviceToken:(NSData *) deviceToken

說明:當(dāng)一個應(yīng)用程序成功的注冊一個推送服務(wù)(APS) 發(fā)送到委托去...

-(void) application:(UIApplication *) applicationdidFailToRegisterForRemoteNotificationsWithError:(NSError *) error

說明:當(dāng) APS無法成功的完成向 程序進(jìn)程推送時 發(fā)送到委托去...

Handling Local Notification (處理本地消息)

-(void) application:(UIApplication *) applicationdidReceiveLocalNotification:(UILocalNotification *)notification

說明:當(dāng)一個運(yùn)行著的應(yīng)用程序收到一個本地的通知 發(fā)送到委托去...

Responding to Content Protections Changes(響應(yīng)受保護(hù)內(nèi)容的改變)

-applicationProtectedDataWillBecomeUnavailable:

說明:通知委托,受保護(hù)的文件當(dāng)前變?yōu)椴豢捎玫?/p>

-applicationProtectedDataWillBecomeAvailable:

說明:通知委托? 受保護(hù)的文件當(dāng)前變?yōu)榭捎?/p>

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容