革新Objective-C的日志输出
发布时间:2021-11-22 09:27:27 所属栏目:PHP教程 来源:互联网
导读:我该如何在日志输出信息中添加上下文信息,例如当前方法或者行号。 C预处理器提供了一些标准宏,可以提供当前文件,行号,或者函数的信息。另外,Objective-C有_cmd隐式参数,可以提供当前函数的选择器,以及将选择器和类转换为字符串的功能。你可以在调试或
我该如何在日志输出信息中添加上下文信息,例如当前方法或者行号。 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] %@ 当前栈信息的刻度字符串数组。仅用于调试,不用向终端用户展示或者在代码中用作任何逻辑。 ![]() (编辑:应用网_丽江站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |