本文共 9447 字,大约阅读时间需要 31 分钟。
当我们新建一个工程的时候,在Supporting FIles文件下会看到一个以 -Prefix.pch结尾文件的文件,pch全称是“precompiled header”,也就是预编译头文件,该文件里存放的工程中一些不常被修改的代码,比如常用的框架头文件,这样做的目的提高编译器编译速度。我们知道当我们修改一个工程中某个文件代码时候,编译器并不是重新编译所有所有文件,而是编译改动过文件的,假如pch中某个文件修改了,那么pch整个文件里包含的的其他文件也会重新编译一次,这样就会消耗大量时间,所以它里面添加的文件最好是是很少变动或不变动的头文件或者是预编译的代码片段;
在新建一个工程时,pch后缀文件里代码是
#import#ifndef __IPHONE_4_0 #warning "This project uses features only available in iOS SDK 4.0 and later." #endif #ifdef __OBJC__ #import #import #endif
// // UIKit.h // UIKit // // Copyright (c) 2005-2011, Apple Inc. All rights reserved. // #import#import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import #import
再来看看我们开源中国iOS客户端pch文件
// // Prefix header for all source files of the 'oschina' target in the 'oschina' project // #import#ifndef __IPHONE_4_0 #warning "This project uses features only available in iOS SDK 4.0 and later." #endif #ifdef __OBJC__ #import #import #import #import //添加的预编译 #import "ASIHTTPRequest.h" #import "ASIFormDataRequest.h" #import "ASIHTTPRequestDelegate.h" #import "ASIHTTPRequestConfig.h" #import "TBXML.h" #import "TBXML+HTTP.h" #import "TBXML+Compression.h" #import "Config.h" #import "EGORefreshTableHeaderView.h" #import "DataSingleton.h" #import "ImgRecord.h" #import "IconDownloader.h" #import "MBProgressHUD.h" #import "GCDiscreetNotificationView.h" #import "NdUncaughtExceptionHandler.h" #import "JSNotifier.h" #import "AFOSCClient.h" #import "AFHTTPRequestOperation.h" #import "AFXMLRequestOperation.h" //api定义 #define api_news_list @"http://www.oschina.net/action/api/news_list" #define api_news_detail @"http://www.oschina.net/action/api/news_detail" #define api_post_list @"http://www.oschina.net/action/api/post_list" #define api_post_detail @"http://www.oschina.net/action/api/post_detail" #define api_post_pub @"http://www.oschina.net/action/api/post_pub" #define api_tweet_list @"http://www.oschina.net/action/api/tweet_list" #define api_tweet_detail @"http://www.oschina.net/action/api/tweet_detail" #define api_tweet_delete @"http://www.oschina.net/action/api/tweet_delete" #define api_tweet_pub @"http://www.oschina.net/action/api/tweet_pub" #define api_active_list @"http://www.oschina.net/action/api/active_list" #define api_message_list @"http://www.oschina.net/action/api/message_list" #define api_message_delete @"http://www.oschina.net/action/api/message_delete" #define api_message_pub @"http://www.oschina.net/action/api/message_pub" #define api_comment_list @"http://www.oschina.net/action/api/comment_list" #define api_comment_pub @"http://www.oschina.net/action/api/comment_pub" #define api_comment_reply @"http://www.oschina.net/action/api/comment_reply" #define api_comment_delete @"http://www.oschina.net/action/api/comment_delete" #define api_login_validate @"https://www.oschina.net/action/api/login_validate" #define api_user_info @"http://www.oschina.net/action/api/user_info" #define api_user_information @"http://www.oschina.net/action/api/user_information" #define api_user_updaterelation @"http://www.oschina.net/action/api/user_updaterelation" #define api_notice_clear @"http://www.oschina.net/action/api/notice_clear" #define api_software_detail @"http://www.oschina.net/action/api/software_detail" #define api_blog_detail @"http://www.oschina.net/action/api/blog_detail" #define api_favorite_list @"http://www.oschina.net/action/api/favorite_list" #define api_favorite_add @"http://www.oschina.net/action/api/favorite_add" #define api_favorite_delete @"http://www.oschina.net/action/api/favorite_delete" #define api_user_notice @"http://www.oschina.net/action/api/user_notice" #define api_search_list @"http://www.oschina.net/action/api/search_list" #define api_friends_list @"http://www.oschina.net/action/api/friends_list" #define api_softwarecatalog_list @"http://www.oschina.net/action/api/softwarecatalog_list" #define api_software_list @"http://www.oschina.net/action/api/software_list" #define api_softwaretag_list @"http://www.oschina.net/action/api/softwaretag_list" #define api_blogcomment_list @"http://www.oschina.net/action/api/blogcomment_list" #define api_blogcomment_pub @"http://www.oschina.net/action/api/blogcomment_pub" #define api_my_information @"http://www.oschina.net/action/api/my_information" #define api_blogcomment_delete @"http://www.oschina.net/action/api/blogcomment_delete" #define api_userblog_delete @"http://www.oschina.net/action/api/userblog_delete" #define api_userblog_list @"http://www.oschina.net/action/api/userblog_list" #define api_blog_list @"http://www.oschina.net/action/api/blog_list" #define api_userinfo_update @"http://www.oschina.net/action/api/portrait_update" //宏定义 新闻 #define TweetCellIdentifier @"TweetCellIdentifier" #define loadMoreIdentifier @"loadMoreIdentifier" #define NewsCellIdentifier @"NewsCellIdentifier" #define PostCellIdentifier @"PostCellIdentifier" #define MsgCellIdentifier @"MsgCellIdentifier" #define MsgUnitCellIdentifier @"MsgUnitCellIdentifier" #define ActiveCellIdentifier @"ActiveCellIdentifier" #define UserActiveCellIdentifier @"UserActiveCellIdentifier" #define ColorActiveCellIdentifier @"ColorActiveCellIdentifier" #define RTActiveCellIdentifier @"RTActiveCellIdentifier" #define ColorUserActiveCellIdentifier @"ColorUserActiveCellIdentifier" #define ProfielCellIdentifier @"ProfielCellIdentifier" #define CommentCellIdentifier @"CommentCellIdentifier" #define NormalCellIdentifier @"NormalCellIdentifier" #define FavoriteCellIdentifier @"FavoriteCellIdentifier" #define FriendCellIdentifier @"FriendCellIdentifier" #define SoftwareCellIdentifier @"SoftwareCellIdentifier" #define SoftwareCatalogIdentifier @"SoftwareCatalogIdentifier" #define SettingTableIdentifier @"SettingTableIdentifier" #define MyInfoCellIdentifier @"MyInfoCellIdentifier" #define MyPortraitCellIdentifier @"MyPortraitCellIdentifier" #define loadNext20Tip @"下面 20 项 . . ." #define loadingTip @"正在加载 . . ." #define networkError @"网络无连接" #define noNetworkTip @"网络无连接" //消息通知固定字符串 #define Notification_DetailCommentCount @"Notification_DetailCommentCount" #define Notification_NoticeUpdate @"Notification_NoticeUpdate" #define Notification_TabClick @"Notification_TabClick" //html头部 #define HTML_Style @" " #define HTML_Bottom @" " #define USERAGENT @"OSChina.NET/iOS/5.0" #define AppVersion @"1.6.1" #ifdef DEBUG #define debugLog(...) NSLog(__VA_ARGS__) #define debugMethod() NSLog(@"%s", __func__) #else #define debugLog(...) #define debugMethod() #endif #endif
我们看到有这样些文件也被添加到里面,可能会想难道这些头文件变化不大吗?
//添加的预编译 #import "ASIHTTPRequest.h" #import "ASIFormDataRequest.h" #import "ASIHTTPRequestDelegate.h" #import "ASIHTTPRequestConfig.h" #import "TBXML.h" #import "TBXML+HTTP.h" #import "TBXML+Compression.h" #import "Config.h" #import "EGORefreshTableHeaderView.h" #import "DataSingleton.h" #import "ImgRecord.h" #import "IconDownloader.h" #import "MBProgressHUD.h" #import "GCDiscreetNotificationView.h" #import "NdUncaughtExceptionHandler.h" #import "JSNotifier.h" #import "AFOSCClient.h" #import "AFHTTPRequestOperation.h" #import "AFXMLRequestOperation.h"其实,这些文件特殊之处在于他们都是第三方类库的头文件,第三方类库将一些对象进行高度封装,留下接口,然后我们根据类库接口直接调用就可以,这些第三方类库一般都比iOS原生自带的更加简单易用,比如TBXML解析库,比iOS自带的NSXMLPaser解析器速度功能上都会好一些;
还有一些宏定义都是比较常用方式的宏定义,比如定义的开源中国社区的api接口,这些接口变得当然很少了;
然后就剩下最后面的
#ifdef DEBUG #define debugLog(...) NSLog(__VA_ARGS__) #define debugMethod() NSLog(@"%s", __func__) #else #define debugLog(...) #define debugMethod() #endif
所以,此处用到了宏指令
上段代码的意思就是 用宏指令做一个判断,如果DEBUG为真,则编译#ifdef到#endif宏定义,否则编译器就不编译;
这个DEBUG在哪设置呢,
在 "Target > Build Settings > Preprocessor Macros > Debug" 里有一个"DEBUG=1"。
现在我们来做一个测试:
取一个宏指令放到OSAppDelegate.m的application:didFinishLaunchingWithOptions:方法中,并用同一个NSLog做一个对比;
NSLog(@"%s", __func__);
debugMethod();
首先设置为Debug模式下,Product-->Edit Scheme
跳转到这个界面
当我设置Build Configuration成Debug时,打印效果图
当我设置Build Configuration成Release的,打印时效果图
当Run Test Profile Analyze Archive的时候,都可以根据需要设置Debug和Release两个模式运行;
所以我们完全可以用一个宏指令来设置是否打印调试信息;
欢迎转载分享,请注明出处
本文转自新风作浪 51CTO博客,原文链接:http://blog.51cto.com/duxinfeng/1208696,如需转载请自行联系原作者