iOS打印Debug日誌的方式

簡單介紹以下幾個宏:

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的時候,不產生任何控制檯輸出

相比而言,還是第一種比較方便

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章