天天看點

【原】iOS學習之PCH檔案

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" // 寫在這裡可能報錯,是以不要寫在這裡