iOS ---不一样的NSLog打印(精准打印)
在iOS开发过程中,调试是很重要的过程,而除了各种断点调试(普通断点、条件断点、全局断点)之外,似乎NSLog是我们调试最常用的方法,当然,也是最简单朴素的寻debug方法。
在项目中,我们常使用的NSLog的语句无外乎以下一种:
NSLog(@"打印字符串:%@",name); NSLog(@"打印整形:%i",number);//或者 %li ; %ld ; %d NSLog(@"打印字符:%c",c); NSLog(@"打印单浮点数:%f",f); NSLog(@"打印精度浮点数:%.2f",f); NSLog(@"BOOL--b-->%@",isYES?@"YES":@"NO");//打印布尔类型
但这样并不是我们想要的结果,因为打印出来的结果,有时我们并不知道它打印的具体位置,甚至于具体信息。打个比方吧,我们经常会遇到的数组越界、网络请求数据为空等等。
我们试一下看看:创建一个空数组-->dataArray,却打印数组的第三个元素。打印结果如下图:
从上图中我们可以看出,一个标准的数组越界,但我们看得出来,debug输出只是说又一个数组越界报错了,但并没有指出是哪个数组,数组在哪个位置。。。试想:如果我们在一个ViewController中有几个数组,这时数组出现越界。就会很难找出到底哪个数组出现debug。那么问题就出现了,怎样才能使用NSLog还能确定位置呢。 下面正式开始要说的话题:不一样的NSLog打印
要使用不一样的NSlog,首先要了解 以下:预处理器在C/C++/objective-C语言提供的宏
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] |
%@ |
当前栈信息的刻度字符串数组。仅用于调试,不用向终端用户展示或者在代码中用作任何逻辑。 |
* __func__%s 当前函数签名
* __LINE__ %d 在源代码文件中当前所在行数 ---->宏在预编译时会替换成当前的行号
* __FILE__ %s 当前源代码文件全路径 -->宏在预编译时会替换成当前的源文件名
* __PRETTY_FUNCTION__ %s 像 __func__,但是包含了C++代码中的隐形类型信息。 ---->宏在预编译时会替换成当前的函数名称
而关于Log,打印当前函数无非就是_cmd, __func__, __FUNCTION__, PRETTY_FUNCTION。
1、打印当前的函数名,以及当前代码所在文件中得行数
NSLog(@"%s, %d", __FUNCTION__, __LINE__);//直接定位到debug的函数名,以及当前代码所在文件中得行数。
在- (void)viewDidLoad中输入以下代码。。。
打印结果如下:
2、打印当前的函数名, NSStringFromSelector 获得参数的选择器所代表的方法的字符串
NSLog(@"%@", NSStringFromSelector(_cmd));
打印结果如下:
3、打印当前源代码文件全路径
NSLog(@"%s", __FILE__);
打印结果如下:
4、使用__PRETTY_FUNCTION__
上面介绍过:像 __func__,但是包含了C++代码中的隐形类型信息。
NSLog(@"%s", __PRETTY_FUNCTION__);
打印结果:
在Xcode中 :
_cmd会返回一个SEL对象,而剩下的都是来自C/C++编译器的定义所以都会返回一个C的字符串,显示结果也都差不多,可能不同编译器会有小小的差别。
显然后面__func__系列要比_cmd好用,相对Objective-C类型内的方法调用,他不仅会显示方法名,还会显示类型,配合__LINE__,可以精确定位出Log在代码中的位置。
以下是我学习时查看的文章,也分享给大家。懂得感恩,懂得尊重它们的劳动成果:
好了,以上就是我想介绍的NSLog有助于开发中定位打印的知识。都是我在接触到喜欢、再到使用的东西。iOS还有很多很多东西是我们不懂的,甚至是毫无所知的。一步一步来,摸索->学习->实践->熟练。每一步都很辛苦,坚持下,往前走会是不一样的风景。
iOS ---不一样的NSLog打印(精准打印)的更多相关文章
- NSLog的各种打印格式符 和 打印CGRect时用NSStringFromCGRect
打印CGRect时用NSStringFromCGRect 转载自:http://blog.csdn.net/chenyong05314/article/details/8219270 1. 打印CG开 ...
- 《c程序设计语言》读书笔记--统计总的字符数,打印能打印的最多字符
#include <stdio.h> #define MAXLINE 10 int getline(char line[],int maxline); void copy(char to[ ...
- C#实现打印与打印预览功能
C#实现打印与打印预览功能的思路及代码. 在windows应用程序中文档的打印是一项非常重要的功能,在以前一直是一个非常复杂的工作,Microsoft .Net Framework的打印功能都以组件的 ...
- C#教程之打印和打印预览
最近研究一了一下关于PDF打印和打印预览的功能,在此小小的总结记录一下学习过程. 实现打印和打印预览的方法,一般要实现如下的菜单项:打印.打印预览.页面设置. PrintDocument类 Print ...
- C#实现打印与打印预览功能(转)
在windows应用程序中文档的打印是一项非常重要的功能,在以前一直是一个非常复杂的工作,Microsoft .Net Framework的打印功能都以组件的方式提供,为程序员提供了很大的方便,但是这 ...
- [转载]IOS项目打包除去NSLog和NSAssert处理之阿堂教程
原文链接地址:http://blog.sina.com.cn/s/blog_81136c2d0102v1ck.html 原文地址:IOS项目打包除去NSLog和NSAssert处理之阿堂教程作者:时空 ...
- android网页打印,安卓网页打印,h5页面打印,浏览器打印,js打印工具
Android设备打印比较麻烦,一般设备厂商都提供原生app开发的SDK,我们web开发者为难了,不会原生开发啊 给大家提供一个思路,实现web加壳,利用打印浏览器实现 简单来说就是把我们的web页面 ...
- WPF实现可视化控件打印及打印预览
打印预览XAML代码: <controls:WindowEx x:Class="SunCreate.Vipf.Client.UI.MapPrintPreview" xmlns ...
- JS实现IE下打印和打印预览
http://blog.csdn.net/rongyongfeikai2/article/details/8460598 ——————————————————————————————————————— ...
随机推荐
- <<< html5本地储存
类似与Cookies,但由于Cookies储存量太小,大小也只有4-5KB的样子,html5的本地储存能存5M大小的数据 html5本地储存属性有,localStorage和sessionStorag ...
- Nodejs - 如何用 eventproxy 模块控制并发
本文目标 本文的目标是获取 ZOJ 1001-1010 每道题 best solution 的作者 id,取得数据后一次性输出在控制台. 前文 如何用 Nodejs 分析一个简单页面 我们讲了如何用 ...
- Web前端框架
框架框架,先框后架.你觉得不方便或者麻烦的地方就像是第一个框(frame)字一样,有点限制住你的感觉.为啥现在你没有觉得有架(work)的感觉呢?其实也在你的问题中提到了:1. 入行时间短,工作比较闲 ...
- 分享一个.NET实现的简单高效WEB压力测试工具
在Linux下对Web进行压力测试的小工具有很多,比较出名的有AB.虽然AB可以运行在windows下,但对于想简单界面操作的朋友有点不太习惯.其实vs.net也提供压力测试功能但显然显得太重了,在测 ...
- iframe子页面点击按钮,执行父页面的点击事件
iframe 子页面点击.parent 父页面 的id(auth-link-btn)的事件 <a href="javascript:void(0);" onclick=&q ...
- golang笔记——函数与方法
如果你遇到没有函数体的函数声明,表示该函数不是以Go实现的. package math func Sin(x float64) float //implemented in assembly lang ...
- tyvj1194 划分大理石
描述 有价值分别为1..6的大理石各a[1..6]块,现要将它们分成两部分,使得两部分价值之和相等,问是否可以实现.其中大理石的总数不超过20000. 输入格式 有多组数据!所以可能有多行如果有0 ...
- IBAction和IBOutlet
- IBAction: - 本质就是void - 能让方法具备连线的功能- IBOutlet - 能让属性具备连线的功能
- windows7安装GitBash和GitGui
安装很简单,搜索安装就行. 配置: 1.$ ssh-keygen -t rsa -C "your_email@youremail.com" 将"your_email@yo ...
- H5播放器
<!DOCTYPE html> <html> <body> <div style="text-align:center"> ...