今天帮同事解决问题的时候发现,程序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. js主要知识轮廓笔记

    一.js中的基础类型和引用类型: 基础类型:1.Number2.String3.Boolean4.Undefined5.Null 引用类型(内置对象):1.Object类型2.Array类型3.Dat ...

  2. 【Away3D代码解读】(一):主要类及说明

    在深入解读Away3D的代码之前,需要对其有个大概的认识.本节主要列出Away3D中常用的类,并附上说明: View3D: Away3D的入口类,即创建该类就会初始化一个可以使用GPU呈现3D的对象, ...

  3. 实现windows和linux互传文件

    http://www.cnblogs.com/ylan2009/archive/2012/01/12/2321126.html 尝试从windows xp向ubuntu11.10传文件 ubuntu使 ...

  4. 判断一个Bitmap图像是否是.9图

    见BitmapFactory的源码中 byte[] np = bm.getNinePatchChunk();  final boolean isNinePatch = np != null & ...

  5. 【转】MyEclipse8.5集成Tomcat7时的启动错误:Exception in thread “main” java.lang.NoClassDefFoundError org/apache/commons/logging/LogFactory

    http://www.cnblogs.com/newsouls/p/4021198.html 今天,安装Tomcat7.0.21后,单独用D:\apache-tomcat-7.0.21\bin\sta ...

  6. 漂亮的自制java验证码

    网上有很多开源的验证码插件,例如jcaptcha,kaptcha等等...这些都不错,不过感觉用起来不太舒服,最后还是网上找了个原型的,然后在这个基础上修改下,效果还算不错,凑合用下,验证码要做到难以 ...

  7. 如何关闭UINavigationController 向右滑动 返回上一层视图

    说明一下: 我的nav 设置的rootview 是 tabbarcontroller,登录界面是push进去的,所以,在登录界面,如果靠近最左边 向右滑动 会出现 tabbarcontroller的视 ...

  8. UART与USART的差别

    UART与USART都是单片机上的串口通信,他们之间的差别例如以下: 首先从名字上看: UART:universal asynchronous receiver and transmitter通用异步 ...

  9. 7Zip 来备份重要文件(夹)

    body { font-family: 宋体,Georgia,Helvetica,Arial,sans-serif,宋体,serif; font-size: 10.5pt; line-height: ...

  10. jquery处理单击和双击事件

    今天做div点击时,需要用到同一div的单击和双击事件,出现问题如下 例子: Html <body> <div id="div_1">单击双击我</d ...