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
看完代码,我们再来看看打印信息。
-- ::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 应用程序启动加载过程(从点击图标到界面显示)的更多相关文章
- 动态符号链接的细节 与 linux程序的加载过程
转: http://hi.baidu.com/clivestudio/item/4341015363058d3d32e0a952 值得玩味的一篇分析程序链接.装载.动态链接细节的好文档 导读: by ...
- redis启动加载过程、数据持久化
背景 公司一年的部分业务数据放在redis服务器上,但数据量比较大,单纯的string类型数据一年就将近32G,而且是经过压缩后的. 所以我在想能否通过获取string数据的时间改为保存list数据类 ...
- Tomcat源码分析三:Tomcat启动加载过程(一)的源码解析
Tomcat启动加载过程(一)的源码解析 今天,我将分享用源码的方式讲解Tomcat启动的加载过程,关于Tomcat的架构请参阅<Tomcat源码分析二:先看看Tomcat的整体架构>一文 ...
- AngularJS进阶(三十九)基于项目实战解析ng启动加载过程
基于项目实战解析ng启动加载过程 前言 在AngularJS项目开发过程中,自己将遇到的问题进行了整理.回过头来总结一下angular的启动过程. 下面以实际项目为例进行简要讲解. 1.载入ng库 2 ...
- java程序的加载过程
昨天笔试阿里有个求java程序加载过程的题目很是复杂,回来研究了好久才有点明白,整理一下.原题代码如下,判断输出: public class StaticTest { public static in ...
- jboss之启动加载过程详解
今天看了看jboss的boot.log和server.log日志,结合自己的理解和其他的资料,现对jboss的启动和加载过程做出如下总结: boot.xml是服务器的启动过程的日志,不涉及后续的操作过 ...
- iOS程序的加载过程
1.执行main函数2.执行UIApplicationMain函数1> 创建一个UIApplication对象(UIApplication是整个程序的象征)一个应用只有一个application ...
- iOS学习之视图加载过程中会触发的方法(loadView/viewDidLoad/didReceiveMemoryWarning)
1.loadView 这是视图控制器用来加载根视图的方法; 如果需要将自定义的视图作为根视图,则不需要调用父类对该方法的实现([super loadView]);直接将自定义视图通过self.view ...
- java web程序启动加载 ContextLoaderListener
浅析ContextLoaderListener 大家可能对下面这段代码再熟悉不过了 <context-param> <param-name>contextConfigLocat ...
随机推荐
- stm32 CAN引脚-笔记
默认: CANRX – > PA11 CANTX - >PA12 映射1: CANRX – > PB8 CANTX - >PB9 映射2: CANRX – > ...
- BootStrap导航栏的使用
默认的导航栏 创建一个默认的导航栏的步骤如下: 向 <nav> 标签添加 class .navbar..navbar-default. 向上面的元素添加 role="naviga ...
- @@IDENTITY与SCOPE_IDENTITY的用法
SCOPE_IDENTITY 和 @@IDENTITY 的作用都是取得返回在当前会话中的任何表内所生成的最后一个标识值,简单的说就是在执行一条插入语句之后使用@@IDENTITY的全局变量 ...
- 代码自动生成工具MyGeneration之一(程序员必备工具)
代码自动生成工具MyGeneration之一(程序员必备工具) 转 分类: C#2008-08-06 18:12 16064人阅读 评论(12) 收藏 举报 工具数据库相关数据库stringbrows ...
- svn 如何解决冲突
项目中,往往不止你一人开发,多人开发,难免会有代码的冲突.彼此间谁也不能保证不会修改同个文件.如果修改了同个方法的内容.这时提交到svn是会提示代码冲突的. 当然,冲突是可控的,但不能避免.每次写代码 ...
- 【原创】OllyDBG 入门系列(一)-认识OllyDBG
****** http://blog.fishc.com/645.html 标 题: [原创]OllyDBG 入门系列(一)-认识OllyDBG作 者: CCDebuger时 间: 2006-0 ...
- hdu 4044 GeoDefense (树形dp | 多叉树转二叉树)
题目链接:hdu-4044 题意 这是一个塔防游戏,地图是一个n个编号为1-n的节点的树, 节点1是敌人的基地,其他叶子节点都是你的基地. 敌人的基地会源源不断地出来怪兽,为了防止敌人攻进你的基 ...
- Android手机中获取手机号码和运营商信息
代码如下: package com.pei.activity; import android.app.Activity; import android.os.Bundle; import androi ...
- [Effective C++ --020]宁以pass-by-reference-to-const替换pass-by-value
前言: 我们都用过C的值传递方式,那么在C++情况下,值传递是怎样工作的呢? 比如: int foo(int x); int i; foo(i); 1.程序内部先取得i的一个副本 2.将副本传递到fo ...
- Apache配置虚拟目录,以及各种操作
apache配置虚拟目录: 打开并创建虚拟目录的步骤如下: # Virtual hosts # Include conf/extra/httpd-vhosts.conf 去掉conf/http.con ...