在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在代码中的位置。

以下是我学习时查看的文章,也分享给大家。懂得感恩,懂得尊重它们的劳动成果:

iOS/Cocoa: 使用代码定位性更高的Log

iOS各种调试技巧豪华套餐

好了,以上就是我想介绍的NSLog有助于开发中定位打印的知识。都是我在接触到喜欢、再到使用的东西。iOS还有很多很多东西是我们不懂的,甚至是毫无所知的。一步一步来,摸索->学习->实践->熟练。每一步都很辛苦,坚持下,往前走会是不一样的风景。

iOS ---不一样的NSLog打印(精准打印)的更多相关文章

  1. NSLog的各种打印格式符 和 打印CGRect时用NSStringFromCGRect

    打印CGRect时用NSStringFromCGRect 转载自:http://blog.csdn.net/chenyong05314/article/details/8219270 1. 打印CG开 ...

  2. 《c程序设计语言》读书笔记--统计总的字符数,打印能打印的最多字符

    #include <stdio.h> #define MAXLINE 10 int getline(char line[],int maxline); void copy(char to[ ...

  3. C#实现打印与打印预览功能

    C#实现打印与打印预览功能的思路及代码. 在windows应用程序中文档的打印是一项非常重要的功能,在以前一直是一个非常复杂的工作,Microsoft .Net Framework的打印功能都以组件的 ...

  4. C#教程之打印和打印预览

    最近研究一了一下关于PDF打印和打印预览的功能,在此小小的总结记录一下学习过程. 实现打印和打印预览的方法,一般要实现如下的菜单项:打印.打印预览.页面设置. PrintDocument类 Print ...

  5. C#实现打印与打印预览功能(转)

    在windows应用程序中文档的打印是一项非常重要的功能,在以前一直是一个非常复杂的工作,Microsoft .Net Framework的打印功能都以组件的方式提供,为程序员提供了很大的方便,但是这 ...

  6. [转载]IOS项目打包除去NSLog和NSAssert处理之阿堂教程

    原文链接地址:http://blog.sina.com.cn/s/blog_81136c2d0102v1ck.html 原文地址:IOS项目打包除去NSLog和NSAssert处理之阿堂教程作者:时空 ...

  7. android网页打印,安卓网页打印,h5页面打印,浏览器打印,js打印工具

    Android设备打印比较麻烦,一般设备厂商都提供原生app开发的SDK,我们web开发者为难了,不会原生开发啊 给大家提供一个思路,实现web加壳,利用打印浏览器实现 简单来说就是把我们的web页面 ...

  8. WPF实现可视化控件打印及打印预览

    打印预览XAML代码: <controls:WindowEx x:Class="SunCreate.Vipf.Client.UI.MapPrintPreview" xmlns ...

  9. JS实现IE下打印和打印预览

    http://blog.csdn.net/rongyongfeikai2/article/details/8460598 ——————————————————————————————————————— ...

随机推荐

  1. Logistic Regression - Formula Deduction

    Sigmoid Function \[ \sigma(z)=\frac{1}{1+e^{(-z)}} \] feature: axial symmetry: \[ \sigma(z)+ \sigma( ...

  2. linux系统下修改文件夹目录权限

    linux系统下修改文件夹目录权限 文件夹权限问题 Linux.Fedora.Ubuntu修改文件.文件夹权限的方法差不多.很多人开始接触Linux时都很头痛Linux的文件权限问题.这里告诉大家如何 ...

  3. javascript parseJSON

    解析json: 前台和后台做ajax交互,后台返回的json字符串,我之前都是通过eval来解析,后来慢慢的知道eval这货是魔鬼,eval要尽量避免,是出于安全考虑,因为eval过于强大,他可以把s ...

  4. Android高手速成--第三部分 优秀项目

    主要介绍那些Android还不错的完整项目,目前包含的项目主要依据是项目有意思或项目分层规范比较好.Linux项目地址:https://github.com/torvalds/linuxAndroid ...

  5. JavaScript闭包(Closure)学习笔记

    闭包(closure)是JavaScript语言的一个难点,也是它的特色,很多高级应用都要依靠闭包实现. 下面就是我的学习笔记,对于JavaScript初学者应该是很有用的. 一.变量的作用域 要理解 ...

  6. PHP exec/system启动windows应用程序,执行.bat批处理,执行cmd命令

    exec 或者 system 都可以调用cmd 的命令 直接上代码: <?php /** 打开windows的计算器 */ exec('start C:WindowsSystem32calc.e ...

  7. .NET读取Excel数据,提示错误:未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序

    解决.NET读取Excel数据时,提示错误:未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序的操作: 1. 检查本机是否安装Office Access,如果未安装去去h ...

  8. 字符串匹配:KMP算法

    一.原理: KMP算法是由Knuth,Morris,Pratt共同提出的模式匹配算法,其对于任何模式和目标序列,都可以在线性时间内完成匹配查找,而不会发生退化,是一个非常优秀的模式匹配算法.朴素算法( ...

  9. JavaScript创建对象及对象继承

    面向对象的语言有一个标志,那就是他们都有类的概念,而通过类可以创建任意多个具有相同属性和方法的对象.但是在ECMAScript中没有类的概念,因此它的对象也与基于类的对象有所不同.实际上,JavaSc ...

  10. mysql查询语句select-子查询

    1 子查询定义 在一个表表达中可以调用另一个表表达式,这个被调用的表表达式叫做子查询(subquery),我么也称作子选择(subselect)或内嵌选择(inner select).子查询的结果传递 ...