今天帮同事解决问题的时候发现,程序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. (莱昂氏unix源代码分析导读-50)LP11行式打印机

    by cszhao1980 LP11有两个设备寄存器:状态寄存器(lpsr)和数据缓冲寄存器(lpbuf),可通过以下结构进行访问: 8812: #define LPADDR 0177514 8823 ...

  2. java反射快速入门(二)

    上一遍博文 , 简单介绍java 反射的常用接口,本遍博文, 我会结合项目开发的实际例子讲解下 java反射的使用 现在有个需求, 要将一个对象转换成xml格式, 或者将一串xml转换一个对象, 这时 ...

  3. 关于Hadoop结合RDBMS应用的一些思考

    最近一段时间一直在从事和hadoop相关的工作,主要是技术内容学习.安装配置优化以及一些框架结构的设计.在此期间,我对于RDBMS和Hadoop的结合应用有了一些自己的看法,写出来大家共同探讨一下. ...

  4. MySQL HA

    读写分离 在应用端处理 Spring AbstractRoutingDataSource 淘宝MyFox MySQL Replication Connection 在数据库端处理 MySQL Prox ...

  5. 《Linux内核修炼之道》 之 高效学习Linux内核

    http://blog.csdn.net/fudan_abc/article/details/5738436

  6. Debian中完全卸载MySQL

      之前服务器上配置测试用的服务环境,我偷懒顺手用网上现成的脚本进行安装,结果MySQL启动不了,于是我只有老老实实的重新安装MySQL Server,原本以为apt-get --purge这类命令可 ...

  7. Mysql数据库导入命令Source详解

    Mysql数据库导入命令Source详解 几个常用用例: 1.导出整个数据库 mysqldump -u 用户名 -p 数据库名 > 导出的文件名 mysqldump -u root -p dat ...

  8. java_利用session校验图片认证码

    RegisterServlet:检验server,client验证码是否一致 ImageServlet: 产生验证码 <!DOCTYPE html> <html> <he ...

  9. Android中Touch事件分析--解决HorizontalScrollView滑动和按钮事件触发问题

    之前写过关于HorizontalScrollView滑动和按钮事件触发问题,但是不能所有的情况,最近几天一直在想这个问题,今天有一个比较好的解决思路,最终应用在项目里面效果也很好,首先说明一下功能: ...

  10. Asp.Net 之 获取GridView行的DataKeys

    1.后台任意一个位置获取GridView行的主键值 foreach (GridViewRow row in GridView1.Rows) { string order_Id=this.GridVie ...