iOS列印Debug日誌的方式,iosdebug日誌

來源:互聯網
上載者:User

iOS列印Debug日誌的方式,iosdebug日誌

簡單介紹以下幾個宏:

1) __VA_ARGS__ 是一個可變參數的宏,這個可變參數的宏是新的C99規範中新增的,目前似乎只有gcc支援(VC6.0的編譯器不支援)。宏前面加上##的作用在於,當可變參數的個數為0時,這裡的##起到把前面多餘的","去掉,否則會編譯出錯。
2) __FILE__ 宏在先行編譯時會替換成當前的源檔案名稱
3) __LINE__宏在先行編譯時會替換成當前的行號
4) __FUNCTION__宏在先行編譯時會替換成當前的函數名稱

 

1.重新定義系統的NSLog,__OPTIMIZE__ 是release 預設會加的宏

 

[plain] view plaincopy 
  1. #ifndef __OPTIMIZE__  
  2. #define NSLog(...) NSLog(__VA_ARGS__)  
  3. #else  
  4. #define NSLog(...){}  
  5. #endif  

 

 

2.直接自己寫#define,當release版本的時候把#define 注釋掉即可

 

#define IOS_DEBUG

 

[plain] view plaincopy 
  1. #ifdef IOS_DEBUG  
  2. #define NSLog(...) NSLog(__VA_ARGS__)  
  3. #endif  

 

3.

[plain] view plaincopy 
  1. #ifdef DEBUG    
  2. # define DLog(format, ...) NSLog((@"[檔案名稱:%s]" "[函數名:%s]" "[行號:%d]" format), __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__);    
  3. #else    
  4. # define DLog(...);    
  5. #endif    

這種方式需要修改項目的配置,使得在debug編譯的時候,編譯DLog的宏,產生詳細的日誌資訊,而release的時候,不產生任何控制台輸出

相比而言,還是第一種比較方便

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.