日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

iOS中的应用启动原理

發布時間:2024/9/5 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 iOS中的应用启动原理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

iOS中的應用啟動原理

來源:?http://m.blog.csdn.net/article/details?id=50530090? http://m.warting.com/program/201601/127355.html http://www.cnblogs.com/zhcios/p/3551034.html

一、UIApplication

?1. 簡單介紹

(1)UIApplication對象是應用程序的象征,一個UIApplication對象就代表一個應用程序。

(2)每一個應用都有自己的UIApplication對象,而且是單例的,如果試圖在程序中新建一個UIApplication對象,那么將報錯提示。

(3)通過[UIApplicationsharedApplication]可以獲得這個單例對象

(4) 一個iOS程序啟動后創建的第一個對象就是UIApplication對象,且只有一個(通過代碼獲取兩個UIApplication對象,打印地址可以看出地址是相同的)。

(5)利用UIApplication對象,能進行一些應用級別的操作

2.應用級別的操作示例:

(1)設置應用程序圖標右上角的紅色提醒數字(如QQ消息的時候,圖標上面會顯示1,2,3條新信息等。)

代碼如下:

@property(nonatomic) NSInteger applicationIconBadgeNumber;
代碼實現和效果:?
- (void)viewDidLoad
{
??? [super viewDidLoad];
// ? UIApplication *app=[[UIApplication alloc]init]; ?//錯誤,只能有一個唯一的UIApplication對象,不能再進行創建 UIApplication *app=[UIApplication sharedApplication];?//通過sharedApplication獲取該程序的UIApplication對象
??? app.applicationIconBadgeNumber=123;
}?

// iOS8之后系統要求,App更改設置通知的時候必須經過用戶認可?

UIApplication *app =[UIApplication sharedApplication];

if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 8.0) {

  UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeBadge categories:nil];

  [app registerUserNotificationSettings:settings];

  app.applicationIconBadgeNumber = 90;

}

(2)設置聯網指示器的可見性

代碼如下:

@property(nonatomic,getter=isNetworkActivityIndicatorVisible) BOOL networkActivityIndicatorVisible;
代碼和效果:? //設置指示器的聯網動畫
??? app.networkActivityIndicatorVisible=YES;

?

(3)管理狀態欄

? a. 通過UIViewController管理(每一個UIViewController都可以擁有自己不同的狀態欄)?

? ?從iOS7開始,系統提供了2種管理狀態欄的方式,默認情況下,狀態欄都是由UIViewController管理的,UIViewController實現下列方法就可以輕松管理狀態欄的可見性和樣式。

?

代碼如下: #pragma mark-設置狀態欄的樣式
-(UIStatusBarStyle)preferredStatusBarStyle
{
??? //設置為白色
??? //return UIStatusBarStyleLightContent;
??? //默認為黑色
???? return UIStatusBarStyleDefault;
}
#pragma mark-設置狀態欄是否隱藏(否)
-(BOOL)prefersStatusBarHidden
{
??? return NO;
} b. 通過UIApplication管理(一個應用程序的狀態欄都由它統一管理)

如果想利用UIApplication來管理狀態欄,首先得修改Info.plist的設置,如圖

代碼如下:

//通過sharedApplication獲取該程序的UIApplication對象 UIApplication *app=[UIApplication sharedApplication];
??? //設置狀態欄的樣式
??? //app.statusBarStyle=UIStatusBarStyleDefault;//默認(黑色)
??? //設置為白色+動畫效果
????? [app setStatusBarStyle:UIStatusBarStyleLightContent animated:YES];
??? //設置狀態欄是否隱藏
??? app.statusBarHidden=YES;
? ? //設置狀態欄是否隱藏+動畫效果
??? [app setStatusBarHidden:YES withAnimation:UIStatusBarAnimationFade];
? c.?既然兩種都可以對狀態欄進行管理,那么什么時候該用什么呢?

如果狀態欄的樣式只設置一次,那就用UIApplication來進行管理;
如果狀態欄是否隱藏,樣式不一樣那就用控制器進行管理。
UIApplication來進行管理有額外的好處,可以提供動畫效果。


?(4)openURL:方法

UIApplication有個功能十分強大的openURL:方法
代碼如下:

- (BOOL)openURL:(NSURL*)url;
openURL:方法的部分功能有

打電話 代碼如下:

UIApplication *app = [UIApplicationsharedApplication]; [app openURL:[NSURLURLWithString:@"tel://10086"]];

發短信 代碼如下:

[app openURL:[NSURLURLWithString:@"sms://10086"]];

發郵件 代碼如下:

[app openURL:[NSURLURLWithString:@"mailto://12345@qq.com"]];?

打開一個網頁資源 代碼如下:

[app openURL:[NSURLURLWithString:@"http://ios.itcast.cn"]];

打開其他app程序?? openURL方法,可以打開其他APP。

?

URL補充:
URL:統一資源定位符,用來唯一的表示一個資源。
URL格式:協議頭://主機地址/資源路徑
網絡資源:http/ ftp等?? 表示百度上一張圖片的地址?? http://www.baidu.com/images/20140603/abc.png
本地資源:file:///users/apple/desktop/abc.png(主機地址省略)
?
二、UIApplication Delegate

1.簡單說明

所有的移動操作系統都有個致命的缺點:app很容易受到打擾。比如一個來電或者鎖屏會導致app進入后臺甚至被終止。

還有很多其它類似的情況會導致app受到干擾,在app受到干擾時,會產生一些系統事件,這時UIApplication會通知它的delegate對象,讓delegate代理來處理這些系統事件。

作用:當被打斷的時候,通知代理進入到后臺。

每次新建完項目,都有個帶有“AppDelegate”字眼的類,它就是UIApplication的代理,NJAppDelegate默認已經遵守了UIApplicationDelegate協議,已經是UIApplication的代理。

?

2.代理方法

代碼如下:

#import "YYAppDelegate.h"

@implementation YYAppDelegate

// 當應用程序啟動完畢的時候就會調用(系統自動調用)
- (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

?

三、UIApplicationMain

1. ?main函數中執行了一個UIApplicationMain這個函數

intUIApplicationMain(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:方法)

程序正常退出時UIApplicationMain函數才返回。


2. 代碼如下:

#import <UIKit/UIKit.h>?

#import "YYAppDelegate.h"

int main(int argc, char * argv[])
{
??? @autoreleasepool {
??????? // return UIApplicationMain(argc, argv, nil, NSStringFromClass([YYAppDelegate class]));
??????? // return UIApplicationMain(argc, argv, @"UIApplication", NSStringFromClass([YYAppDelegate class]));
???????? return UIApplicationMain(argc, argv, @"UIApplication", @"YYAppDelegate");
??? }
}


3. 系統入口的代碼和參數說明:

argc:系統或者用戶傳入的參數
argv:系統或用戶傳入的實際參數?
1.根據傳入的第三個參數,創建UIApplication對象
2.根據傳入的第四個產生創建UIApplication對象的代理
3.設置剛剛創建出來的代理對象為UIApplication的代理
4.開啟一個事件循環(可以理解為里面是一個死循環)這個時間循環是一個隊列(先進先出)先添加進去的先處理
?

四、程序啟動的完整過程

1. ?有storyboard文件?
1. 調用main函數?
2. 調用UIApplicationMain函數?
3. 創建UIApplication對象 、 AppDelegate對象?
4. 設置UIApplicatio對象的代理是AppDelegate對象。?
5. AppDelegate對象開始監聽”系統事件(應用程序的事件)”,進入”事件循環”?
6. 程序啟動完畢后調用 application: didFinishLaunchingWithOptions:方法。?
7. 在application: didFinishLaunchingWithOptions:方法中自動創建?
* UIWindow對象。?
* 根據Info.plist文件配置(Main Interface),找到需要加載的storyboard文件(Main.storyboard)?
* 找到Main.storyboard中的Is Initial View Controller 對應的控制器類, 創建該控制器對象。?
* 根據storyboard中的配置, 創建控制器對應的view。?
* 設置UIWindow的根控制器(rootViewController)為剛才創建的控制器。?
* 顯示UIWindow([self.window makeKeyAndVisible])。?

2. 沒有storyboard文件?
1. 調用main函數。?
2. 調用UIApplicationMain函數。?
3. 創建UIApplication對象 、 AppDelegate對象?
4. 設置UIApplicatio對象的代理是AppDelegate對象。?
5. AppDelegate對象開始監聽”系統事件(應用程序的事件)”,進入”事件循環”。?
6. 程序啟動完畢后調用 application: didFinishLaunchingWithOptions:方法。?
7. 在application: didFinishLaunchingWithOptions:方法中手動創建:?
* UIWindow?
* 控制器?
* 設置UIWindow的根控制器是剛才創建的控制器?
* 顯示UIWindow

?3. ios程序啟動原理圖解

4. 四大對象關系圖?

轉載于:https://www.cnblogs.com/stevenwuzheng/p/5214678.html

總結

以上是生活随笔為你收集整理的iOS中的应用启动原理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。