1. PCH檔案概述
- PCH檔案是一種預編譯頭檔案(一般擴充名為.PCH),是把一個工程中較穩定的代碼預先編譯好放在一個檔案(.PCH)裡。這些預先編譯好的代碼可以是任何的C/C++代碼--甚至可以是inline函數,隻它們在整個工程中是較為穩定的,即在工程開發過程中不會經常被修改的代碼。
- 在 Xcode6.0 之前的版本中,生成的 Single View Application 工程中自動存在PCH檔案,Xcode6.0 之後就去掉了pch,為了一些瑣碎的頭檔案引用,加快了編譯速度!
- 如圖為 Xcode5 的工程截圖:
2. PCH檔案的建立(Xcode6.0 之前的版本)
在工程中 command + N —> iOS中的 Other —> PCH File —> Next —> Create
PCH檔案是提前編譯的,是以我們要告訴工程。具體操作如下圖:
當然如果想要填寫的話,可以使用 $(SRCROOT) 來擷取你工程檔案的路徑,完整可以寫為:$(SRCROOT)/PCHTest/header.pch
3. PCH檔案的作用
- 存放一些公用的宏
- 存放一些公用的頭檔案,一般開發中方工具類的頭檔案或者分類頭檔案等。
- 管理日志輸出
自定義Log: #define ZFLog(…) NSLog(__VA__ARGS__)
宏裡面的可變參數:...
函數中的可變參數:__VA__ARGS__
日志輸出非常耗性能,一般釋出的時候不需要日志檔案,隻有調試的時候才需要。
在釋出上線的時候,我們有兩種簡單的方式來消除在工程中所有的日志輸出
① 我們可以直接注釋後面的 #define ZFLog(…) // NSLog(__VA__ARGS__),就可以消除在工程中所有的日志輸出
② 還可以通過一個宏進行條件編譯,在調試階段,xcode會自動定義一個DEBUG宏,利用這個宏,就能進行條件編譯。
#ifdef DEBUG // 調試階段
#define ZFLog(…) NSLog(__VA__ARGS__)
#else // 釋出階段
#define ZFLog(…)
#endif
4. PCH檔案使用注意事項
在 PCH 寫的有關 OC 的東西,最好放在 #ifdef __OBJC__ ,Xcode 在每個 OC 檔案中都定義了這個宏,也就意味着隻有 OC 中的檔案才擁有這些宏,避免項目中有 C 檔案的時候,報錯。
比如在c檔案中,使用 #import ,就會報錯,因為c檔案不能識别 #import , 隻有 OC 檔案才能識别。在 PCH 中的東西能被項目中的所有檔案共享, C 檔案共享 #import 就報錯。
#ifdef __OBJC__ // OC檔案的正确寫法
#import <UIKit/UIKit.h>
#import <Foundation/Foundation.h>
#endif
#import "ZFTool.h" // 寫在這裡可能報錯,是以不要寫在這裡