http://www.linuxidc.com/Linux/2012-08/67623.htm
簡單介紹以下幾個宏:
1) __VA_ARGS__ 是一個可變參數的宏,這個可變參數的宏是新的C99規範中新增的,目前似乎隻有gcc支援(VC6.0的編譯器不支援)。宏前面加上##的作用在于,當可變參數的個數為0時,這裡的##起到把前面多餘的","去掉,否則會編譯出錯。
2) __FILE__ 宏在預編譯時會替換成目前的源檔案名
3) __LINE__宏在預編譯時會替換成目前的行号
4) __FUNCTION__宏在預編譯時會替換成目前的函數名稱
1.重新定義系統的NSLog,__OPTIMIZE__ 是release 預設會加的宏
- #ifndef __OPTIMIZE__
- #define NSLog(...) NSLog(__VA_ARGS__)
- #else
- #define NSLog(...){}
- #endif
2.直接自己寫#define,當release版本的時候把#define 注釋掉即可
- #define IOS_DEBUG
- #ifdef IOS_DEBUG
- #define NSLog(...) NSLog(__VA_ARGS__)
- #endif
3.
- #ifdef DEBUG
- # define DLog(format, ...) NSLog((@"[檔案名:%s]" "[函數名:%s]" "[行号:%d]" format), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__);
- #else
- # define DLog(...);
- #endif
這種方式需要修改項目的配置,使得在debug編譯的時候,編譯DLog的宏,産生詳細的日志資訊,而release的時候,不産生任何控制台輸出。
相比而言,還是第一種比較友善。