簡單介紹以下幾個宏:
1) __VA_ARGS__ 是一個可變參數的宏,這個可變參數的宏是新的C99規范中新增的,目前似乎隻有gcc支持(VC6.0的編譯器不支持)。宏前面加上##的作用在於,當可變參數的個數為0時,這裡的##起到把前面多餘的","去掉,否則會編譯出錯。
2) __FILE__ 宏在預編譯時會替換成當前的源文件名
3) __LINE__宏在預編譯時會替換成當前的行號
4) __FUNCTION__宏在預編譯時會替換成當前的函數名稱
1. 在***-Prefix.pch裡面添加, 重新定義系統的NSLog,__OPTIMIZE__ 是release 默認會加的宏
#ifndef__OPTIMIZE__
#defineNSLog(…)NSLog(__VA_ARGS__)
#else
#defineNSLog(…){}
#endif
2.在***-Prefix.pch裡面添加 ,直接自己寫#define,當release版本的時候把#define 註釋掉即可
#defineIOS_DEBUG
#ifdefIOS_DEBUG
#defineNSLog(…)NSLog(__VA_ARGS__)
#endif
3.在***-Prefix.pch裡面添加
#ifdefDEBUG
#defineDLog(format,…)NSLog((@"[文件名:%s]""[函數名:%s]""[行號:%d]"format),__FILE__,__FUNCTION__,__LINE__,##__VA_ARGS__);
#else
#defineDLog(…);
#endif
這種方式需要修改項目的配置,使得在debug編譯的時候,編譯DLog的宏,產生詳細的日志信息,而release的時候,不產生任何控制臺輸出相比而言,還是第一種比較方便