標籤:__line__ 函數 行號 __file__ 方便 form 日誌 orm vc6
簡單介紹以下幾個宏: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的時候,不產生任何控制台輸出相比而言,還是第一種比較方便
iOS開發debug跟release版本NSLog屏蔽方法