在iOS開發(fā)中普气,大家經(jīng)常會使用NSLog跟蹤應用中可能產生的問題卖漫。但是NSLog會消耗資源,所以在Release的版本中最好屏蔽它至会。
首先確定什么是Debug版本,什么是Release版本谱俭。在Edit Scheme...對話框中的Run中可以設置Debug和Release奉件。在Product->Archive生成的ipa文件都是Release吧本宵蛀。
簡單介紹以下幾個宏:
1) __VA_ARGS__ 是一個可變參數(shù)的宏,這個可變參數(shù)的宏是新的C99規(guī)范中新增的县貌,目前似乎只有gcc支持(VC6.0的編譯器不支持)术陶。宏前面加上##的作用在于,當可變參數(shù)的個數(shù)為0時煤痕,這里的##起到把前面多余的","去掉,否則會編譯出錯梧宫。
2) __FILE__ 宏在預編譯時會替換成當前的源文件名
3) __LINE__宏在預編譯時會替換成當前的行號
4) __FUNCTION__宏在預編譯時會替換成當前的函數(shù)名稱
1. 添加#ifndef __OPTIMIZE__,__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杭攻,DEBUG是debug版本默認會添加的宏
#ifdef DEBUG
# define DLog(format, ...) NSLog((@"[文件名:%s]""[函數(shù)名:%s]""[行號:%d]"format), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__);
#else
# define DLog(...);
#endif
這種方式需要修改項目的配置祟敛,使得在debug編譯的時候,編譯DLog的宏兆解,產生詳細的日志信息馆铁,而release的時候,不產生任何控制臺輸出锅睛。相比而言埠巨,第一種比較簡單,第三種比較詳細现拒。