国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

IOS應用程序啟動加載過程(從點擊圖標到界面顯示)

2019-11-14 19:12:39
字體:
來源:轉載
供稿:網友

  今天幫同事解決問題的時候發現,程序BUG是由加載過程引起的。所以當局部代碼沒有問題,但是程序一運行卻總不是我們想要結果的時候,我們應該想想是不是因為我們忽略了試圖加載過程的原因。下面我們用一個例子來簡單介紹一下啟動過程中常見的幾個方法。首先我們通過XIB 創建了一個試圖控制器(名字叫Empty ,不要問我為為啥它叫這個名字,因為我太懶了,鼠標點快了就沒去改),又創建了一個UIView的子類(MyView),并且將Empty的對象 設置為窗口的根控制器,MyView 的一個對象設置為Empty的主視圖。OK,了解了以上的內容,我們就可以寫代碼了。

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {        NSLog(@"%s",__func__);        //加載控制器    Empty* test=[[Empty alloc] initWithNibName:@"Empty" bundle:nil];    //新建窗口    UIWindow *window=[[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];    self.window=window;        //將創建的控制器設置為根控制器    self.window.rootViewController=test;        //激活并顯示窗口    [self.window makeKeyAndVisible];    return YES;}

由于我們的應用程序并不是直接通過故事板創建的,所以我們要自己設定跟控制器。在應用程序調用didFinishLaunchingWithOptions:之前,會先查看是否能通過故事板來創建視圖控制器,如果找不到的話則需要我們手動創建window和控制器。由于我們想知道各個方法的執行過程,所以我們要在各個方法中加上方法的打印信息。Empty視圖控制器代碼如下:

#import "MyView.h"#import "Empty.h"@interface Empty ()@end@implementation Empty//再程序一啟動的時候就調用各個類的load方法 正如官方說說的 無論這個類是否會加載到runtime中,它都會被調用。//Invoked whenever a class or category is added to the Objective-C runtime;+(void)load{    NSLog(@"%s",__func__);}//這個方法只會調用一次,再init之前。如果一個類創建了10個對象,那么init會執行10次,但是該方法只會執行一次。+(void)initialize{    NSLog(@"%s",__func__);}//這個就不說了 太熟悉了-(instancetype)init{    NSLog(@"%s",__func__);    return [super init];}-(instancetype)initWithCoder:(NSCoder *)aDecoder{    NSLog(@"%s",__func__);    return [super initWithCoder:aDecoder];}//當從nib 中加載的時候 會調用這個方法-(instancetype)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil{    NSLog(@"%s",__func__);    if (self=[super initWithNibName:nibNameOrNil bundle:nibBundleOrNil])    {           }    return self;}//初始化完成后就開始加載視圖,注意一點,控制器創建完成了并不代表它的視圖已經加載好了,視圖是懶加載的,使用時應注意。-(void)loadView{    NSLog(@"loadview");    [super loadView];    UIView *view=[[MyView alloc] init];    view.backgroundColor=[UIColor yellowColor];    self.view=view;        }// 當觸發約束時調用-(void)updateViewConstraints{    NSLog(@"%s",__func__);    [super updateViewConstraints];  }//當視圖加載完成后調用,如果視圖不是被銷毀后再重新顯示的話,那么它只會執行一次- (void)viewDidLoad{    NSLog(@"%s",__func__);    [super viewDidLoad];    }//視圖已經顯示-(void)viewDidAppear:(BOOL)animated{    [super viewDidAppear:animated];    NSLog(@"%s",__func__);}//視圖即將顯示-(void)viewWillAppear:(BOOL)animated{    [super viewWillAppear:animated];    NSLog(@"%s",__func__);}

以上是控制器類,該說的再代碼里都說了。下面是MyView中的代碼。

#import "MyView.h"@implementation MyView//繪圖- (void)drawRect:(CGRect)rect{    NSLog(@"%s",__func__);}+(void)load{    NSLog(@"%s",__func__);}// 為子視圖設置布局 一般在這里進行各個子控件的frame-(void)layoutSubviews{    [super layoutSubviews];    NSLog(@"%s",__func__);}@end

看完代碼,我們再來看看打印信息。

2015-04-21 00:26:00.123 Runloop[19756:1191521] +[Empty load]2015-04-21 00:26:00.124 Runloop[19756:1191521] +[MyView load]2015-04-21 00:26:00.309 Runloop[19756:1191521] -[AppDelegate application:didFinishLaunchingWithOptions:]2015-04-21 00:26:00.309 Runloop[19756:1191521] +[Empty initialize]2015-04-21 00:26:00.309 Runloop[19756:1191521] -[Empty initWithNibName:bundle:]2015-04-21 00:26:00.310 Runloop[19756:1191521] loadview2015-04-21 00:26:00.314 Runloop[19756:1191521] -[Empty viewDidLoad]2015-04-21 00:26:00.314 Runloop[19756:1191521] -[Empty viewWillAppear:]2015-04-21 00:26:00.315 Runloop[19756:1191521] -[MyView layoutSubviews]2015-04-21 00:26:00.315 Runloop[19756:1191521] -[MyView layoutSubviews]2015-04-21 00:26:00.316 Runloop[19756:1191521] -[MyView drawRect:]2015-04-21 00:26:00.350 Runloop[19756:1191521] -[Empty viewDidAppear:]

請忽略項目名,因為今天本來想些runloop的,唉~世事難料啊~~~

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 台北市| 西乌珠穆沁旗| 增城市| 稷山县| 雷波县| 静海县| 盘锦市| 锡林郭勒盟| 南漳县| 页游| 依安县| 汽车| 镇远县| 临武县| 民权县| 平果县| 连南| 怀安县| 北宁市| 长子县| 旅游| 南城县| 临沂市| 鄂尔多斯市| 饶河县| 临朐县| 博乐市| 阜南县| 礼泉县| 淮滨县| 襄樊市| 美姑县| 乃东县| 温泉县| 温宿县| 清河县| 新绛县| 麻城市| 洛浦县| 新源县| 岳普湖县|