-Prefix.pch结尾文件的文件,pch全称是“precompiled header”,也就是预编译头文件,该文件里存放的工程中一些不常被修改的代码,比如常用的框架头文件,这样做的目的提高编译器编译速度我们知道当我们修改一个工程中某个文件代码时候,编译器并不是重新编译所有所有文件,而是编译改动过文件的,假如pch中某个文件修改了,那么pch整个文件里包含的的其他文件也会重新编译一次,这样就会消耗大量时间,所以它里面添加的文件最好是是很少变动或不变动的头文件或者是预编译的代码片段;
当Precompile Prefix Header为YES,那么pch会被预编译,预编译后的pch文件会被缓存起来,从而提高编译速度。当Precompile Prefix Header为NO时,那么pch不会被预编译,而是在每一个用到它导入的框架类库的.m文件中编译一次。
#import <Availability.h>
#ifndef __IPHONE_4_0
#warning "This project uses features only available in iOS SDK 3.0 and later."
#endif
#ifdef __OBJC__
#import <UIKit/UIKit.h>
#import <Foundation/Foundation.h>
#import "MCConst.h"
#import "IQKeyboardManager.h"
#import "MCCrouseDetailViewController.h"
#endif
再来看看我们开源中国iOS客户端pch文件
[cpp] view plain copy
- //
- // Prefix header for all source files of the 'oschina' target in the 'oschina' project
- //
- #import <Availability.h>
- #ifndef __IPHONE_4_0
- #warning "This project uses features only available in iOS SDK 4.0 and later."
- #endif
- #ifdef __OBJC__
- #import <UIKit/UIKit.h>
- #import <Foundation/Foundation.h>
- #import <CoreData/CoreData.h>
- #import <QuartzCore/QuartzCore.h>
- //添加的预编译
- #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 @"<style>#oschina_title {color: #000000; margin-bottom: 6px; font-weight:bold;}#oschina_title img{vertical-align:middle;margin-right:6px;}#oschina_title a{color:#0D6DA8;}#oschina_outline {color: #707070; font-size: 12px;}#oschina_outline a{color:#0D6DA8;}#oschina_software{color:#808080;font-size:12px}#oschina_body img {max-width: 300px;}#oschina_body {font-size:16px;max-width:300px;line-height:24px;} #oschina_body table{max-width:300px;}#oschina_body pre { font-size:9pt;font-family:Courier New,Arial;border:1px solid #ddd;border-left:5px solid #6CE26C;background:#f6f6f6;padding:5px;}</style>"
- #define HTML_Bottom @"<div style='margin-bottom:60px'/>"
- #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
- 其实,这些文件特殊之处在于他们都是第三方类库的头文件,第三方类库将一些对象进行高度封装,留下接口,然后我们根据类库接口直接调用就可以,这些第三方类库一般都比iOS原生自带的更加简单易用,比如TBXML解析库,比iOS自带的NSXMLPaser解析器速度功能上都会好一些;
- 还有一些宏定义都是比较常用方式的宏定义,比如定义的开源中国社区的api接口,这些接口变得当然很少了;
- [cpp] view plain copy
- #ifdef DEBUG
- #define debugLog(...) NSLog(__VA_ARGS__)
- #define debugMethod() NSLog(@"%s", __func__)
- #else
- #define debugLog(...)
- #define debugMethod()
- #endif
- 工程有Debug Version和Release Version,Debug Version是程序开发过程中版本,它包含了所有调试信息,一些常用的NSLog打印日志,在程序调试过程工根据我们设置的调试信息可以看出什么地方出错,我们在运行运行一个小程序的时候,会不会首先就想到进行断点调试呢,应该是首先想着NSLog一下,看看哪个函数方法没执行,看看是不是哪个数组的值没取出来。Release Version是发布版本,不打印NSLog可以加快程序运行速度,减少内存使用。 但是到一个大工程中,会有很多很多这样的NSLog,在我们工程完美运行的时候,发布Release 版本的时候,难道我们去一行行的注释调NSLog吗?假如工程现在原来基础上发布一个version 1.2版本的,我们在修改程序的时候岂不是还把原来注释给取消,那就很麻烦很麻烦了。
- 所以,此处用到了宏指令
- 上段代码的意思就是 用宏指令做一个判断,如果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
debug版本有信息打出,而release版本没有信息打出