今天帮同事解决问题的时候发现,程序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

看完代码,我们再来看看打印信息。

-- ::00.123 Runloop[:] +[Empty load]
-- ::00.124 Runloop[:] +[MyView load]
-- ::00.309 Runloop[:] -[AppDelegate application:didFinishLaunchingWithOptions:]
-- ::00.309 Runloop[:] +[Empty initialize]
-- ::00.309 Runloop[:] -[Empty initWithNibName:bundle:]
-- ::00.310 Runloop[:] loadview
-- ::00.314 Runloop[:] -[Empty viewDidLoad]
-- ::00.314 Runloop[:] -[Empty viewWillAppear:]
-- ::00.315 Runloop[:] -[MyView layoutSubviews]
-- ::00.315 Runloop[:] -[MyView layoutSubviews]
-- ::00.316 Runloop[:] -[MyView drawRect:]
-- ::00.350 Runloop[:] -[Empty viewDidAppear:]

请忽略项目名,因为今天本来想些runloop的,唉~世事难料啊~~~

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

  1. 动态符号链接的细节 与 linux程序的加载过程

    转: http://hi.baidu.com/clivestudio/item/4341015363058d3d32e0a952 值得玩味的一篇分析程序链接.装载.动态链接细节的好文档 导读: by ...

  2. redis启动加载过程、数据持久化

    背景 公司一年的部分业务数据放在redis服务器上,但数据量比较大,单纯的string类型数据一年就将近32G,而且是经过压缩后的. 所以我在想能否通过获取string数据的时间改为保存list数据类 ...

  3. Tomcat源码分析三:Tomcat启动加载过程(一)的源码解析

    Tomcat启动加载过程(一)的源码解析 今天,我将分享用源码的方式讲解Tomcat启动的加载过程,关于Tomcat的架构请参阅<Tomcat源码分析二:先看看Tomcat的整体架构>一文 ...

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

    基于项目实战解析ng启动加载过程 前言 在AngularJS项目开发过程中,自己将遇到的问题进行了整理.回过头来总结一下angular的启动过程. 下面以实际项目为例进行简要讲解. 1.载入ng库 2 ...

  5. java程序的加载过程

    昨天笔试阿里有个求java程序加载过程的题目很是复杂,回来研究了好久才有点明白,整理一下.原题代码如下,判断输出: public class StaticTest { public static in ...

  6. jboss之启动加载过程详解

    今天看了看jboss的boot.log和server.log日志,结合自己的理解和其他的资料,现对jboss的启动和加载过程做出如下总结: boot.xml是服务器的启动过程的日志,不涉及后续的操作过 ...

  7. iOS程序的加载过程

    1.执行main函数2.执行UIApplicationMain函数1> 创建一个UIApplication对象(UIApplication是整个程序的象征)一个应用只有一个application ...

  8. iOS学习之视图加载过程中会触发的方法(loadView/viewDidLoad/didReceiveMemoryWarning)

    1.loadView 这是视图控制器用来加载根视图的方法; 如果需要将自定义的视图作为根视图,则不需要调用父类对该方法的实现([super loadView]);直接将自定义视图通过self.view ...

  9. java web程序启动加载 ContextLoaderListener

    浅析ContextLoaderListener 大家可能对下面这段代码再熟悉不过了 <context-param> <param-name>contextConfigLocat ...

随机推荐

  1. Java字节码(.class文件)格式详解(一)

    原文链接:http://www.blogjava.net/DLevin/archive/2011/09/05/358033.html 小介:去年在读<深入解析JVM>的时候写的,记得当时还 ...

  2. Gitbook安装

    Gitbook安装 Gitbook是从NMP安装的,命令行: $ npm install gitbook -g 安装完之后,你可以检验下是否安装成功: $ gitbook -V 0.4.2 如果你看到 ...

  3. CSDN首页> 移动开发 直接拿来用!最火的Android开源项目(完结篇)

    此前,CSDN移动频道推出的GitHub平台上“最受欢迎的开源项目”系列文章引发了许多读者的热议,在“直接拿来用!最火的Android开源项目”系列文章(一).(二)中,我们也相继盘点了40个GitH ...

  4. iOS开发笔记系列-基础2(类)

    面向对象编程总是离不开类和对象的,Objective-C也不例外,不过Objective-C中的类还有一些自己的独特点. 类的声明和定义 在iOS开发中,类的声明与定义通常都是分开的,类得声明通常存放 ...

  5. js判断字符在另一个字符串中出现次数

    经过搜索验证,提供两个方法. 1. 通过分割获取长度原理 var s = 'www.51qdq.com';var n = (s.split('.')).length-1;alert(n);  //弹出 ...

  6. HDU 5433 Xiao Ming climbing dp

    Xiao Ming climbing Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://bestcoder.hdu.edu.cn/contests/ ...

  7. 飘逸的python - 理解打开文件的模式

    当我们用open()函数去打开文件的时候,有好几种打开的模式.   'r'->只读 'w'->只写,文件已存在则清空,不存在则创建. 'a'->追加,写到文件末尾 'b'->二 ...

  8. UVa 131 - The Psychic Poker Player

    题目:手里有五张牌,桌上有一堆牌(五张).你能够弃掉手中的k张牌,然后从牌堆中取最上面的k个. 比較规则例如以下:(按优先级排序) 1.straight-flush:同花顺.牌面为T(10) - A, ...

  9. android开发学习:打电话和发短信

    1.新建一个android项目 File--New--Other--android application project 填写application name(就是应用的名字.比方:天天酷跑) 填写 ...

  10. WebAPI返回JSON的正确格式

    最近打算用WebAPI做服务端接口,返回JSON供ANDROID程序调用,结果试了好几次JSONObject都无法解析返回的JSON字符串.看了一下服务端代码: public string Get() ...