簡單介紹以下幾個宏:
1) __VA_ARGS__ 是一個可變參數(shù)的宏鼻弧,這個可變參數(shù)的宏是新的C99規(guī)范中新增的叉存,目前似乎只有g(shù)cc支持(VC6.0的編譯器不支持)。宏前面加上##的作用在于,當(dāng)可變參數(shù)的個數(shù)為0時练俐,這里的##起到把前面多余的","去掉,否則會編譯出錯腺晾。
2) __FILE__ 宏在預(yù)編譯時會替換成當(dāng)前的源文件名
3) __LINE__宏在預(yù)編譯時會替換成當(dāng)前的行號
4) __FUNCTION__宏在預(yù)編譯時會替換成當(dāng)前的函數(shù)名稱
1.重新定義系統(tǒng)的NSLog悯蝉,__OPTIMIZE__ 是release 默認(rèn)會加的宏
#ifndef __OPTIMIZE__
#define NSLog(...) NSLog(__VA_ARGS__)
#else
#define NSLog(...){}
#endif
2.直接自己寫#define,當(dāng)release版本的時候把#define 注釋掉即可
#define IOS_DEBUG
#ifdef IOS_DEBUG
#define NSLog(...) NSLog(__VA_ARGS__)
#endif
3.
#ifdef DEBUG
# define DLog(format, ...) NSLog((@"[文件名:%s]" "[函數(shù)名:%s]" "[行號:%d]" format), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__);
#else
# define DLog(...);
#endif
這種方式需要修改項(xiàng)目的配置嗡靡,使得在debug編譯的時候歉井,編譯DLog的宏,產(chǎn)生詳細(xì)的日志信息菩貌,而release的時候戈鲁,不產(chǎn)生任何控制臺輸出婆殿。
相比而言,還是第一種比較方便。