我該如何在日誌輸出信息中添加上下文信息,例如當前方法或者行號。數組
C預處理器提供了一些標準宏,能夠提供當前文件,行號,或者函數的信息。另外,Objective-C有_cmd隱式參數,能夠提供當前函數的選擇器,以及將選擇器和類轉換爲字符串的功能。你能夠在調試或者錯誤處理時在NSLog語句中提供這些上下文信息。app
下面是打印當前方法和行號的例子。ide
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中用於日誌輸出的預處理宏.ui
Macro | Format Specifier | Description |
__func__ | %s | 當前函數前面 |
__LINE__ | %d | 源碼文件中的行號 |
__FILE__ | %s | 源碼文件完整路徑 |
__PRETTY_FUNCTION__ | %s | 和__func__相似, 可是在 C++ 代碼中包含更多的信息. |
Objective-C中用於日誌輸出的表達式spa
Expression | Format Specifier | Description |
NSStringFromSelector(_cmd) | %@ | 當前選擇器的名字 |
NSStringFromClass([self class]) | %@ | 當前對象類的名字 |
[[NSString stringWithUTF8String:__FILE__] lastPathComponent] | %@ | 源碼文件的名稱 |
[NSThread callStackSymbols] | %@ |
當前棧信息的刻度字符串數組。僅用於調試,不用向終端用戶展現或者在代碼中用做任何邏輯。調試 |