你好,歡迎來到IOS教程網

 Ios教程網 >> IOS編程開發 >> IOS開發綜合 >> iOS開發PCH文件、NSLog真機不打印

iOS開發PCH文件、NSLog真機不打印

編輯:IOS開發綜合

添加PCH文件

現在Xcode6、7創建一個新的工程時將默認不會再帶有PCH文件,需要手動添加PCH文件。

在Supporting Files目錄下,選擇 File > New > File > iOS > Other > PCH File 然後點擊下一步進行命名,建議命名格式為項目名稱-Prefix,如圖Demo
這裡寫圖片描述 創建的PCH文件與編譯器Xcode進行連接:找到 Project > Build Settings > 搜索 “Prefix Header“; 在Apple LLVM X.0 -Language欄目中能夠找到Prefix Header,雙擊之後添加該PCH文件地址,如圖所示:
這裡寫圖片描述
這樣Xcode6、7的PCH文件就能夠順利加到工程中去了。

NSLog函數真機不打印

在實際項目中NSLog函數打印信息是必不可少的事情,可以友好的幫助我們調試程序,然而在模擬器上占用的是電腦的內存,但在真機上線時如果不把NSLog函數屏蔽掉,勢必會造成內存的占用,性能的減弱,這對做一款優秀的App的出發點是十分違背的,所以在真機中借助PCH設置全局變量不打印NSLog函數是實戰項目中必不可少的要求。

在剛才建立的PCH中對NSLog進行改造:

  #ifdef DEBUG

  #define DLog(fmt, ...) NSLog((@"[文件名:%s]\n" "[函數名:%s]\n" "[行號:%d] \n" fmt), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__);

  #define DeBugLog(fmt, ...) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__);

 #define NSLog(...) NSLog(__VA_ARGS__);
 #define MyNSLog(FORMAT, ...) fprintf(stderr,"[%s]:[line %d行] %s\n",[[[NSString stringWithUTF8String:__FILE__] lastPathComponent] UTF8String], __LINE__, [[NSString stringWithFormat:FORMAT, ##__VA_ARGS__] UTF8String]);
  #else
  #define DLog(...)
  #define DeBugLog(...)
  #define NSLog(...)
  #define MyNSLog(FORMAT, ...) nil
  #endif

 
* 1) VA_ARGS 是一個可變參數的宏,很少人知道這個宏,這個可變參數的宏是新的C99規范中新增的,目前似乎只有gcc支持(VC6.0的編譯器不支持)。宏前面加上##的作用在於,當可變參數的個數為0時,這裡的##起到把前面多余的”,”去掉的作用,否則會編譯出錯, 你可以試試。

2) FILE 宏在預編譯時會替換成當前的源文件名

3) LINE宏在預編譯時會替換成當前的行號

4) FUNCTION宏在預編譯時會替換成當前的函數名稱

OK了,測試一下吧!真機與模擬的互相切換

這裡寫圖片描述
這裡寫圖片描述

  1. 上一頁:
  2. 下一頁:
蘋果刷機越獄教程| IOS教程問題解答| IOS技巧綜合| IOS7技巧| IOS8教程
Copyright © Ios教程網 All Rights Reserved