NSLog打印日志技巧
2015-08-07 16:57
260 查看
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++ 代码中包含更多的信息. |
Expression | Format Specifier | Description |
NSStringFromSelector(_cmd) | %@ | 当前选择器的名字 |
NSStringFromClass([self class]) | %@ | 当前对象类的名字 |
[[NSString stringWithUTF8String:__FILE__] lastPathComponent] | %@ | 源码文件的名称 |
[NSThread callStackSymbols] | %@ | 当前栈信息的刻度字符串数组。仅用于调试,不用向终端用户展示或者在代码中用作任何逻辑。 |
相关文章推荐
- Linux学习笔记
- ng-bind-html在ng-repeat中问题的解决办法
- PHP运行模式
- linux下find命令详解
- HDU 1058
- Google代码规范工具Cpplint的使用
- h264 - I帧 B帧 P帧 IDR帧的关系
- 基数排序算法
- 常用的正则表达式
- 讲解 hashCode() 方法和 equals() 方法的文章(转载)
- HibernateCallback对象 回调方法用来创建gethibernatetemplate没有的方法
- Android+PHP+Mysql实现用户登录
- Google代码规范工具Cpplint的使用
- log4js-Node.js中的日志管理模块使用与封装【转】
- Linux一些经典书籍
- Linux 常用命令
- ssh-copy-id
- List数据集动态排序
- 第二十八篇:SOUI中自定义控件开发过程
- jQuery基于ajax实现星星评论代码