轉 iOS開發debug跟release版本log屏蔽方法


簡單介紹以下幾個宏:
1) __VA_ARGS__ 是一個可變參數的宏,這個可變參數的宏是新的C99規范中新增的,目前似乎只有gcc支持(VC6.0的編譯器不支持)。宏前面加上##的作用在於,當可變參數的個數為0時,這里的##起到把前面多余的","去掉,否則會編譯出錯。
2) __FILE__ 宏在預編譯時會替換成當前的源文件名
3) __LINE__宏在預編譯時會替換成當前的行號
4) __FUNCTION__宏在預編譯時會替換成當前的函數名稱

1. 在***-Prefix.pch里面添加,  重新定義系統的NSLog,__OPTIMIZE__ 是release 默認會加的宏
#ifndef __OPTIMIZE__  
#define NSLog(...) NSLog(__VA_ARGS__)  
#else  
#define NSLog(...){}  
#endif  
2.在***-Prefix.pch里面添加  ,直接自己寫#define,當release版本的時候把#define 注釋掉即可
#define IOS_DEBUG
#ifdef IOS_DEBUG #define NSLog(...) NSLog(__VA_ARGS__) #endif 3.在***-Prefix.pch里面添加 #ifdef DEBUG # define DLog(format, ...) NSLog((@"[文件名:%s]" "[函數名:%s]" "[行號:%d]" format), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__); #else # define DLog(...); #endif 這種方式需要修改項目的配置,使得在debug編譯的時候,編譯DLog的宏,產生詳細的日志信息,而release的時候,不產生任何控制台輸出 相比而言,還是第一種比較方便

轉:http://blog.csdn.net/lixuwen521/article/details/7675836

參考:

http://blog.csdn.net/weiqubo/article/details/7438264

http://li-bonan.blog.163.com/blog/static/135564770201291232340740/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM