iOS程序启动原理(上)

本文介绍iOS程序中的Info.plist,pch文件,UIApplication,openURL以及UIWindow的常用属性及方法;

info.plist

常见设置

建立一个工程后,会在Supporting files文件夹下看到一个"工程名-Info.plist"的文件,该文件对工程做一些运行期的配置,非常重要,不能删除.
在旧版Xcode创建的工程中,这个配置文件的名字叫做"Info.plist".
项目中的其他plist文件不能带有"Info"这个字眼,不然会被错认为是传说中非常重要的"Info.plist".
项目中还有一个"InfoPlist.strings"的文件(Xcode6之后需手动添加),跟Info.plist文件的本地化相关.

Info.plist常见属性:

  1. Localiztion native development region (CFBundleDevelopmentRegion)-本地化相关;
  2. Bundle display name(CFBundleDisplayName)-程序安装后显示的名称,限制在10-12个字符,如果超出,将被显示缩写名称;
  3. Icon file(CFBundleIconFile)-app图标名称,一般为Icon.png;
  4. Bundle version(CFBundleVersion)-应用程序的版本号,每次往App Store上发布一个新版本时,需要增加这个版本号;
  5. Main storyboard file base name(NSMainStoryboardFile)-主storyboard文件名称;
  6. Bundle identifier(CFBundleIdentifier)-项目的唯一标识,部署到真机时用到;
  7. 额外说一下从iOS9开始,所有的http请求都改成了https,采用TLS 1.2协议,目的是增强数据安全。如果不更新的话,暂时可以在Info.plist中声明,使用不安全的网络请求。
    可以在info.plist中添加一下字段
    <key>NSAppTransportSecurity</key>
    <dict>
    <key>NSAllowsArbitraryLoads</key>
    <true/>
    </dict>

    即如:

pch文件

项目的Supporting files文件夹下面有个"工程名-Prefix.pch"文件,也是一个头文件;

pch头文件的内容能被项目中的其他所有源文件共享和访问;

一般在pch头文件中定义一些全局的宏;

在pch头文件中添加下列预处理指令,然后在项目中使用Log(...)来输出日志信息,就可以在发布应用的时候,一次性将NSLog语句移除(在调试模式下,才有定义DEBUG)
    #ifdef DEBUG
    #define Log(...) NSLog(__VA_ARGS__)
    #else#define Log(...) /* */
    #endif``

UIApplication

UIApplication对象是应用程序的象征;
每一个应用都有自己的UIApplication对象,而且是单例的;
通过[UIApplication sharedApplication]可以获得这个单例对象;
一个iOS程序启动后创建的第一个对象就是UIApplication对象;
利用UIApplication对象,能进行一些应用级别的操作.

UIApplication的常用属性

设置应用程序图标右上角的红色提醒数字:
@property(nonatomic) NSInteger applicationIconBadgeNumber;
设置联网指示器(菊花)的可见性
@property(nonatomic,getter=isNetworkActivityIndicatorVisible) BOOL networkActivityIndicatorVisible;

状态栏

从iOS7开始,系统提供了两种管理状态栏的方式:

1.>通过UIViewController管理(在iOS中,默认情况下,状态栏都是由UIViewController管理的):
状态栏的样式:
- (UIStatusBarStyle)preferredStatusBarStyle;
状态栏的可见性
- (BOOL)prefersStatusBarHidden;
2.>通过UIApplication管理(一个应用程序的状态栏都由它统一管理)
application.statusBarHidden = NO;

openURL:

UIApplication有个功能十分强大的openURL方法:
- (BOOL)openURL:(NSURL*)url;
openURL:方法的部分功能有

  • 打电话
    UIApplication *app = [UIApplication sharedApplication];
    [app openURL:[NSURL URLWithString:@"tel://10086"]];
  • 发短信
    [app openURL:[NSURL URLWithString:@"sms://10086"]];
  • 发邮件
    [app openURL[NSURL URLWithString:@"mailto://605453790@qq.com"]];
  • 打开一个网页资源
    [app openURL:[NSURL URLWithString:@"http://www.baidu.com"]];
  • 打开其他app程序
    NSString *urlString = [NSString stringWithFormat:@"AppJumpSecond://%@",textField.text];
    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:urlString]];

UIApplication和delegate

所有的移动操作系统都有个致命的缺点:app很容易受到打扰.比如一个来电或者锁屏会导致app进入后台甚至被终止;

还有很多其他类似的情况会导致app受到干扰,在app受到干扰时,会产生一些系统事件,这时UIApplication会通知它的delegate对象,让delegate来处理这些系统事件.

delegate可处理的事件包括:

1> 应用程序的生命周期事件(如程序的启动和关闭);

2> 系统事件(如来电);

3> 内存警告...

UIApplicationDelegate协议

// app接收到内存警告时调用
- (void)applicationDidReceiveMemoryWarning:(UIApplication *)application;
// app进入后台时调用(比如按了home键)
- (void)applicationDidEnterBackground:(UIApplication *)application;
// app启动完毕时调用
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions;

每次新建完项目,都有个带有"AppDelegate"字眼的类,它就是UIApplication的代理,AppDelegate默认已经遵守了UIApplicationDelegate协议,已经是UIApplication的代理;

UIWindow

UIWindow是一种特殊的UIView,通常在一个App中只会有一个UIWindow;
iOS程序启动完毕后,创建的第一个视图控件就是UIWindow,接着创建控制器的View,最后将控制器的view添加到UIWindow上,于是控制器的view就显示在屏幕上了.
一个程序之所以能显示在屏幕上,完全是因为它有UIWindow,没有UIWindow,就看不见任何UI界面;
添加UIView到UIWindow中的两种常见方式:
1> 直接将view添加到UIWindow中,但并不会理会view对应的UIViewController
- (void)addSubview:(UIView *)view;

2> 自动将rootViewController的view添加到UIWindow中,负责管理rootViewController的生命周期;

@property(nonatomic,retain) UIViewController *rootViewController;

常用方法:
- (void)makeKeyWindow; //让当前UIWindow变成keyWindow(主窗口)
- (void)makeKeyAndVisible; //让当前UIWindow变成keyWindow,并显示出来

UIWindow的获得:

[UIApplication sharedApplication].windows

在本应用中打开的UIWindow列表,这样就可以接触应用中的任何一个UIView对象(平时输入文字弹出的键盘,就处在一个新的UIWindow中).

[UIApplication sharedApplication].keyWindow

用来接收键盘以及非触摸类的消息事件的UIWindow,而且程序中每时每刻只能有一个UIWindow是keyWindow.如果某个UIWindow内部的文本框不能输入文字,可能是因为这个UIWindow不是keyWindow.

view.window

获得某个UIView所在的UIWindow.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 156,757评论 4 359
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,478评论 1 289
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 106,540评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,593评论 0 203
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,903评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,329评论 1 210
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,659评论 2 309
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,383评论 0 195
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,055评论 1 238
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,337评论 2 241
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,864评论 1 256
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,227评论 2 251
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,820评论 3 231
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 25,999评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,750评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,365评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,260评论 2 258

推荐阅读更多精彩内容