簡單介紹如下幾個宏:
1) __VA_ARGS__ 是一個可變參數的宏,這個可變參數的宏是新的C99規範中新增的,目前彷佛只有gcc支持(VC6.0的編譯器不支持)。
宏前面加上##的做用在於,當可變參數的個數爲0時,這裏的##起到把前面多餘的","去掉,不然會編譯出錯。
2) __FILE__ 宏在預編譯時會替換成當前的源文件名
3) __LINE__宏在預編譯時會替換成當前的行號
4) __FUNCTION__宏在預編譯時會替換成當前的函數名稱xcode
#ifndef __OPTIMIZE__ #define NSLog(...) NSLog(__VA_ARGS__) #else #define NSLog(...){} #endif
#define IOS_DEBUG #ifdef IOS_DEBUG #define NSLog(...) NSLog(__VA_ARGS__) #endif
#ifdef DEBUG # define DLog(format, ...) NSLog((@"[文件名:%s]" "[函數名:%s]" "[行號:%d]" format), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__); #else # define DLog(...); #endif
這種方式須要修改項目的配置,使得在debug編譯的時候,編譯DLog的宏,產生詳細的日誌信息,而release的時候,不產生任何控制檯輸出。
相比而言,仍是第一種比較方便函數
檢查DEBUG標誌是否正肯定義,xcode通常會在debug運行配置項裏面已經定義號了DEBUG標誌,若是沒定義咱們就本身寫上。
找到PreProcessor Macros 這個屬性,對於Debug配置咱們給他寫上DEBUG,而在Release配置中把它留空。
這樣咱們剛纔那段預處理命令就能夠根據這個標誌來判斷咱們編譯的時調試版本仍是發佈版本,從而控制NSLog的輸出。
spa
https://blog.csdn.net/meegomeego/article/details/9966659.net