現在Xcode6、7創建一個新的工程時將默認不會再帶有PCH文件,需要手動添加PCH文件。
在Supporting Files目錄下,選擇 File > New > File > iOS > Other > PCH File 然後點擊下一步進行命名,建議命名格式為項目名稱-Prefix,如圖Demo在實際項目中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宏在預編譯時會替換成當前的函數名稱