开源中国iOS客户端学习——(一)Prefix.pch文件

简介:

         当我们新建一个工程的时候,在Supporting FIles文件下会看到一个以  -Prefix.pch结尾文件的文件,pch全称是“precompiled header”,也就是预编译头文件,该文件里存放的工程中一些不常被修改的代码,比如常用的框架头文件,这样做的目的提高编译器编译速度。我们知道当我们修改一个工程中某个文件代码时候,编译器并不是重新编译所有所有文件,而是编译改动过文件的,假如pch中某个文件修改了,那么pch整个文件里包含的的其他文件也会重新编译一次,这样就会消耗大量时间,所以它里面添加的文件最好是是很少变动或不变动的头文件或者是预编译的代码片段;


在新建一个工程时,pch后缀文件里代码是

#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> #endif 

或许你会觉得这预编译代码很少,但是你可以查看一下UIKit.h的定义文件中

// //  UIKit.h //  UIKit // //  Copyright (c) 2005-2011, Apple Inc. All rights reserved. //  #import <UIKit/UIKitDefines.h> #import <UIKit/UIAccelerometer.h> #import <UIKit/UIAccessibility.h>  #import <UIKit/UIActivityIndicatorView.h> #import <UIKit/UIAlert.h> #import <UIKit/UIApplication.h> #import <UIKit/UIBarButtonItem.h> #import <UIKit/UIBarItem.h> #import <UIKit/UIBezierPath.h> #import <UIKit/UIButton.h> #import <UIKit/UIColor.h> #import <UIKit/UIControl.h> #import <UIKit/UIDataDetectors.h> #import <UIKit/UIDatePicker.h> #import <UIKit/UIDevice.h> #import <UIKit/UIDocument.h> #import <UIKit/UIDocumentInteractionController.h> #import <UIKit/UIEvent.h> #import <UIKit/UIFont.h> #import <UIKit/UIGeometry.h> #import <UIKit/UIGestureRecognizer.h> #import <UIKit/UIGraphics.h> #import <UIKit/UIImage.h> #import <UIKit/UIImagePickerController.h> #import <UIKit/UIImageView.h> #import <UIKit/UIInterface.h> #import <UIKit/UILabel.h> #import <UIKit/UILocalNotification.h> #import <UIKit/UILocalizedIndexedCollation.h> #import <UIKit/UILongPressGestureRecognizer.h> #import <UIKit/UIManagedDocument.h> #import <UIKit/UIMenuController.h> #import <UIKit/UINavigationBar.h> #import <UIKit/UINavigationController.h> #import <UIKit/UINib.h> #import <UIKit/UINibDeclarations.h> #import <UIKit/UINibLoading.h> #import <UIKit/UIPageControl.h> #import <UIKit/UIPageViewController.h> #import <UIKit/UIPanGestureRecognizer.h> #import <UIKit/UIPasteboard.h> #import <UIKit/UIPickerView.h> #import <UIKit/UIPinchGestureRecognizer.h> #import <UIKit/UIPopoverController.h> #import <UIKit/UIPopoverBackgroundView.h> #import <UIKit/UIPrintError.h> #import <UIKit/UIPrintFormatter.h> #import <UIKit/UIPrintInfo.h> #import <UIKit/UIPrintInteractionController.h> #import <UIKit/UIPrintPageRenderer.h> #import <UIKit/UIPrintPaper.h> #import <UIKit/UIProgressView.h> #import <UIKit/UIReferenceLibraryViewController.h> #import <UIKit/UIResponder.h> #import <UIKit/UIRotationGestureRecognizer.h> #import <UIKit/UIScreen.h> #import <UIKit/UIScreenMode.h> #import <UIKit/UIScrollView.h> #import <UIKit/UISearchBar.h> #import <UIKit/UISearchDisplayController.h> #import <UIKit/UISegmentedControl.h> #import <UIKit/UISlider.h> #import <UIKit/UISplitViewController.h> #import <UIKit/UIStepper.h> #import <UIKit/UIStoryboard.h> #import <UIKit/UIStoryboardPopoverSegue.h> #import <UIKit/UIStoryboardSegue.h> #import <UIKit/UIStringDrawing.h> #import <UIKit/UISwipeGestureRecognizer.h> #import <UIKit/UISwitch.h> #import <UIKit/UITabBar.h> #import <UIKit/UITabBarController.h> #import <UIKit/UITabBarItem.h> #import <UIKit/UITableView.h> #import <UIKit/UITableViewCell.h> #import <UIKit/UITableViewController.h> #import <UIKit/UITapGestureRecognizer.h> #import <UIKit/UITextField.h> #import <UIKit/UITextInput.h> #import <UIKit/UITextInputTraits.h> #import <UIKit/UITextView.h> #import <UIKit/UIToolbar.h> #import <UIKit/UITouch.h> #import <UIKit/UIVideoEditorController.h> #import <UIKit/UIView.h> #import <UIKit/UIViewController.h> #import <UIKit/UIWebView.h> #import <UIKit/UIWindow.h>

这些不少了吧,工程每次运行都编译是不是很费时间,这些是苹果公司内部定义的标准头文件,我们不能也没有权限修改这些头文件定义内容,所以,当放到pch文件中会加速编译过程;


再来看看我们开源中国iOS客户端pch文件

// // 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 


我们看到有这样些文件也被添加到里面,可能会想难道这些头文件变化不大吗?

//添加的预编译 #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 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

跳转到这个界面


当我设置Build Configuration成Debug时,打印效果图


当我设置Build Configuration成Release的,打印时效果图


当Run  Test  Profile  Analyze  Archive的时候,都可以根据需要设置Debug和Release两个模式运行;

所以我们完全可以用一个宏指令来设置是否打印调试信息;




欢迎转载分享,请注明出处http://blog.csdn.net/duxinfeng2010





     本文转自新风作浪 51CTO博客,原文链接:http://blog.51cto.com/duxinfeng/1208696,如需转载请自行联系原作者




相关文章
|
26天前
|
移动开发 前端开发 数据安全/隐私保护
iOS发布证书.p12文件无密码解决办法及导出带密码的新.p12文件方法
iOS发布证书.p12文件无密码解决办法及导出带密码的新.p12文件方法
26 0
|
5月前
|
Linux Android开发 iOS开发
基于.Net开发的ChatGPT客户端,兼容Windows、IOS、安卓、MacOS、Linux
基于.Net开发的ChatGPT客户端,兼容Windows、IOS、安卓、MacOS、Linux
86 0
|
6月前
|
存储 网络安全 数据安全/隐私保护
最新版 苹果 IOS AppStore证书申请全流程 包括p12文件
最新版 苹果 IOS AppStore证书申请全流程 包括p12文件
|
2月前
|
Linux 数据安全/隐私保护 iOS开发
如何使用 Xcode 打包导出 IPA 文件并进行 iOS 应用内测,无需支付苹果开发者账号费用?
如何使用 Xcode 打包导出 IPA 文件并进行 iOS 应用内测,无需支付苹果开发者账号费用?
|
2月前
|
Web App开发 Go iOS开发
【IOS】教你如何在手机端轻松安装 ipa 文件 -(安装器已失效 21.10)|社区征文
【IOS】教你如何在手机端轻松安装 ipa 文件 -(安装器已失效 21.10)|社区征文
|
3月前
|
Web App开发 Go iOS开发
【IOS】教你如何在手机端轻松安装 ipa 文件 -(安装器已失效 21.10)
【IOS】教你如何在手机端轻松安装 ipa 文件 -(安装器已失效 21.10)
|
27天前
|
移动开发 监控 小程序
mPaaS常见问题之uniapp ios端云打包的配置config文件如何解决
mPaaS(移动平台即服务,Mobile Platform as a Service)是阿里巴巴集团提供的一套移动开发解决方案,它包含了一系列移动开发、测试、监控和运营的工具和服务。以下是mPaaS常见问题的汇总,旨在帮助开发者和企业用户解决在使用mPaaS产品过程中遇到的各种挑战
22 0
|
28天前
|
iOS开发 开发者
【教程】uni-app iOS 打包解决 profile 文件与私钥证书不匹配问题
【教程】uni-app iOS 打包解决 profile 文件与私钥证书不匹配问题
|
6月前
|
网络安全 开发工具 数据安全/隐私保护
如何把ipa文件(iOS安装包)安装到iPhone手机上? 附方法汇总
如何把ipa文件(iOS安装包)安装到iPhone手机上? 附方法汇总
|
6月前
|
移动开发 前端开发 数据安全/隐私保护
iOS发布证书.p12文件无密码解决办法及导出带密码的新.p12文件方法
本文将以iOS技术博主身份,分享解决使用无密码的.p12文件发布应用时遇到的问题,并介绍如何以带密码的方式重新导出.p12文件的方法。通过本文提供的步骤,开发者可以顺利完成证书的发布流程。