改善Objective-C的日誌輸出

 

 

我該如何在日誌輸出信息中添加上下文信息,例如當前方法或者行號。

 

C預處理器提供了一些標準宏,可以提供當前文件,行號,或者函數的信息。另外,Objective-C有_cmd隱式參數,可以提供當前函數的選擇器,以及將選擇器和類轉換爲字符串的功能。你可以在調試或者錯誤處理時在NSLog語句中提供這些上下文信息。

 

下面是打印當前方法和行號的例子。

NSMutableArray *someObject = [NSMutableArray array];
NSLog(@"%s:%d someObject=%@", __func__, __LINE__, someObject);
[someObject addObject:@"foo"];
NSLog(@"%s:%d someObject=%@", __func__, __LINE__, someObject);

 

下面是在日誌語句中很有用的非常常見的宏和表達式。

C/C++/Objective-C中用於日誌輸出的預處理宏.

Macro Format Specifier Description
__func__ %s 當前函數前面
__LINE__ %d 源碼文件中的行號
__FILE__ %s 源碼文件完整路徑
__PRETTY_FUNCTION__ %s 和__func__類似, 但是在 C++ 代碼中包含更多的信息.
     

Objective-C中用於日誌輸出的表達式

Expression Format Specifier Description
NSStringFromSelector(_cmd) %@
當前選擇器的名字
NSStringFromClass([self class]) %@ 當前對象類的名字
[[NSString stringWithUTF8String:__FILE__] lastPathComponent] %@
源碼文件的名稱
[NSThread callStackSymbols] %@

 

當前棧信息的刻度字符串數組。僅用於調試,不用向終端用戶展示或者在代碼中用作任何邏輯。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章