IOS 应用程序启动加载过程(从点击图标到界面显示)

  今天帮同事解决问题的时候发现,造成程序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] loadview
2015-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的,唉~世事难料啊~~~

时间: 2024-10-10 13:23:20

IOS 应用程序启动加载过程(从点击图标到界面显示)的相关文章

AngularJS进阶(三十九)基于项目实例解析ng启动加载过程

基于项目实例解析ng启动加载过程 前言 在AngularJS项目开发过程中,自己将遇到的问题进行了整理.回过头来总结一下angular的启动过程. 下面以实际项目为例进行简要讲解. 1.载入ng库 2.等待,直到DOM树构造完毕. 3.发现ng-app,自动进入启动引导阶段. 4.根据ng-app名称找到相应的路由. 5.加载默认地址. 6.Js顺序执行,加载相应模版页 sys_tpls/home.html 7.在此,可以看到index路由中只是填充了ui-view为sys_login的div模

ViewController启动加载过程

ViewController加载过程(ShowViewCycle是ViewController.view的subView): 1. -[ViewController initWithNibName:bundle:] [Line 82] nibNameOrNil:(null), nibBundleOrNil:(null) ViewController初始化方法, ViewController安一下顺序在 mainBundle 中 (因第二个参数 nibBundle 也指定为 nil) 搜索 NIB

关于iOS中页面启动加载的相关问题汇总

博主昨天看了些李明杰老师的关于UIWindow以及加载View的视频,觉得有必要一篇技术博客来记录一下,一来是为了给自己学到的东西做一下总结,二来也希望能够对一些对这方面知识不是很熟悉的人,补充一下知识点,废话不多说,进入正题. 一.首先是关于APP在运行后,执行的顺序 就是先执行main.m,然后执行AppDelegate,然后再在AppDelegate中初始化视图的容器UIWindow,最后再创建一个控制器的View在UIWindow中显示出来. 二.接下来说一下关于UIWindow载入Vi

Linux内核启动及文件系统加载过程

上接博文<u-boot之u-boot-2009.11启动过程分析> 当u-boot开始执行bootcmd命令,就进入Linux内核启动阶段,与u-boot类似,普通Linux内核的启动过程也可以分为两个阶段,但针对压缩了的内核如uImage就要包括内核自解压过程了.本文以项目中使用的linux-2.6.37版源码为例分三个阶段来描述内核启动全过程.第一阶段为内核自解压过程,第二阶段主要工作是设置ARM处理器工作模式.使能MMU.设置一级页表等,而第三阶段则主要为C代码,包括内核初始化的全部工作

IOS中的生命周期及加载过程

这一节,主要讲解UIKit框架下,应用程序的生命周期,UIView的生命周期,异常处理流程及控制器的加载过程. 四大对象关系图 应用程序生命周期 对上面的流程进行说明: 1. 程序启动执行,先进入main函数: int main(int argc, char * argv[]) 2. 执行UIApplicationMain函数: return UIApplicationMain(argc, argv, nil, NSStringFromClass([HKAppDelegate class]));

spring启动component-scan类扫描加载过程---源码分析

有朋友最近问到了 spring 加载类的过程,尤其是基于 annotation 注解的加载过程,有些时候如果由于某些系统部署的问题,加载不到,很是不解!就针对这个问题,我这篇博客说说spring启动过程,用源码来说明,这部分内容也会在书中出现,只是表达方式会稍微有些区别,我将使用spring 3.0的版本来说明(虽然版本有所区别,但是变化并不是特别大),另外,这里会从WEB中使用spring开始,中途会穿插自己通过newClassPathXmlApplicationContext 的区别和联系.

【Spring源码分析系列】启动component-scan类扫描加载过程

原文地址:http://blog.csdn.net/xieyuooo/article/details/9089441/ 在spring 3.0以上大家都一般会配置一个Servelet,如下所示: 1 <servlet> 2 <servlet-name>spring</servlet-name> 3 <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-clas

spring启动component-scan类扫描加载过程(转)

文章转自 http://www.it165.net/pro/html/201406/15205.html 有朋友最近问到了 spring 加载类的过程,尤其是基于 annotation 注解的加载过程,有些时候如果由于某些系统部署的问题,加载不到,很是不解!就针对这个问题,我这篇博客说说spring启动过程,用源码来说明,这部分内容也会在书中出现,只是表达方式会稍微有些区别,我将使用spring 3.0的版本来说明(虽然版本有所区别,但是变化并不是特别大),另外,这里会从WEB中使用spring

iOS之nib、xib及storyboard的区别及storyboard的加载过程

先讲述下nib, nib是3.0版本以前的产物,在终端下我们可以看到,NIB其实是一个文件夹,里面有可执行的二进制文件: 区分xib和storyboard的区别? 不同点: 1> 无论nib也好,xib也好,最终在执行UIViewController生命周期函数loadView之前,都会转化成可执行的nib文件. 2> storyboard是多个xib文件集合的描述文件,一个xib文件对应着一个视图控制器和多个视图. toryboard时,一个工程只需要一个主storyboard文件就可以.