iOS高效调试

写代码难免出现bug。 储备些调试技能绝对能够提高你的工作效率,让bug无所遁形。下面就和大家分享一些我在工作中常用的iOS调试小技能。

1. 打印

最简单,基础的调试方法就是打印日志了。贴出两段封装好的日志打印代码:


  1. //swift版 
  2. func DLog(message: T, file: String = #file, method: String = #function, line: Int = #line) { 
  3.     #if DEBUG 
  4.         print(", \(method)  \(message)") 
  5.     #endif 
  6.   
  7. //OC版 
  8. #ifdef DEBUG 
  9.      #define DLog(fmt, ...) NSLog((@" %s  " fmt), [[[NSString stringWithUTF8String:__FILE__] lastPathComponent]   UTF8String], __LINE__, __PRETTY_FUNCTION__,  ##__VA_ARGS__); 
  10. #else 
  11.     #define DLog(...) 
  12. #endif 

eg:


  1. //在AppDelegate.m中调用下面的方法 
  2. - (void)applicationDidFinishLaunching:(UIApplication *)application{ 
  3.     DLog(@"hello world"); 
  4. //打印结果: 2016-09-18 17:19:27.931 DateCell[2901:1622220]  -[AppDelegate applicationDidFinishLaunching:]  hello world 

2. 断点

(1)普通断点

普通断点是调试中最常使用的。当程序运行到断点处就会暂停运行。其设置方法非常简单:在需要设置断点的代码行的左侧单击即可。

普通断点

(2)条件断点(为断点添加条件和其他属性,暂且就称它条件断点)

条件断点是在普通断点的基础上添加了判断条件。当程序执行到断点处,并且满足设置的条件时断点才会有效。设置方法如下:

打开断点编辑框

这里写图片描述

在上面的设置中,条件断点的条件是 i==3, 那么在整个循环中只有在i=3时程序才会在断点处停止执行。

在 Edit Breakpoint…窗口中有下面四个输入项:

  • Condition 设置的条件。
  • Ignore 表示忽略多少次之后断点有效。例如:不设置条件,Ignore设置为4,则i=4时程序在断点处停止。
  • Action 在程序断点处执行的操作(执行完这个操作后代码停止运行,此时设置断点处的代码还没有执行)。这里的操作是LLDB语句,关于LLDB会在下面介绍。
  • Options 当选中时,执行完Action的操作后代码不会停止,就像没有设置断点一样。

(3)异常断点Exception BreakPoint

在设置异常断点的情况下 当程序crash时 Xcode会帮我们定位到crash产生的位置。

没有异常断点的情况

设置异常断点的情况

设置异常断点步骤:

这里写图片描述

(4)符号断点Symbolic Breakpoint

符号断点能够为某一个方法或者 某一个类的某一个方法设置断点。实现的功能如下图:

某一个类的某一个方法设置断点

在某个方法中执行断点

设置步骤如下:

符号断点设置步骤

3. LLDB

LLDB的Xcode默认的调试器, 我们通过执行LLDB命令使调试过程更加的灵活。

Xcode内嵌LLDB调试窗口。在程序执行到断点后你可以输入LLDB命令操作调试过程。



LLDB常用命令如下:

1, po (print object)输出对象, 如 po [self view];

2, p (print)用于输出基本类型, 如 p (int)[[[self view] subviews] count] 输出子视图个数。

3, expr (expression) 可以在调试时动态执行指定表达式,并将结果打印出来。常用于在调试过程中修改变量的值。例如上图所示,程序第一次执行到断点时

执行下面的指令:expr i=4

你会看到如下的输出: (int) $0 = 4

继续运行程序,程序输出的信息是:value:4 i==4

4, call call即是调用的意思。其实上述的po和p也有调用的功能。因此一般只在不需要显示输出,或是方法无返回值时使用call。我们可以在viewDidLoad:里面设置断点,然后在程序中断的时候输入下面的命令: call [self.view setBackgroundColor:[UIColor redColor]] 此时view的背景颜色变为红色。

5, bt 打印调用堆栈,加all可打印所有thread的堆栈。不详细举例说明,感兴趣的朋友可以自己试试。

6, fr v -R 命令来打印出变量的未加工过时的信息

如果想了解更详细的内容,戳这里。

http://lldb.llvm.org/tutorial.html

4. Chisel

Chisel是 facebook开源的用于界面调试的lldb命令。

安装

Chisel 使用 homebrew 来安装,如果你没有安装homebrew, 参考 homebrew。


  1. brew update 
  2. brew install chisel 

安装完成后,在~/.lldbinit 中添加如下内容, 没有~/.lldbinit则新建。


  1. # ~/.lldbinit 
  2. ... 
  3. command script import /path/to/fblldb.py 

重启Xcode, 此时Chisel就可以使用了。

命令



命令集合

英语不好的同学可以看这里。

https://blog.cnbluebox.com/blog/2015/03/05/chisel/

5. 界面调试利器: Reveal

Reveal 绝对是iOS界面调试利器。只要用上一次你就会离不开它。对于Reveal的介绍可以去官网了解。

安装

Reveal是收费的,提倡正版。下面的破解版只供教学使用,不可用于生产环境。

1, 从官网(https://revealapp.com/)下载Reveal并安装;

2,下载破解文件(https://pan.baidu.com/s/1bNPhlO) 提取密码:7×48;

3,破解步骤见破解文件中的使用说明。

4, 打开Reveal,开始使用。Reveal的新版本可能修改验证逻辑,如果没有破解成功那就使用正版的吧。

在项目中配置

在使用Reveal之前需要对iOS项目进行简单配置。

配置方法1:

Reveal可以使用cocoa pods导入:在Podfile文件中导入 pod ‘Reveal’, ‘~> 1.3’。

配置方法

如果不使用cocoa pods,配置起来略有麻烦。下面是详细的配置过程:

1, 使用Xcode打开你想要查看UI的工程;

2, 打开Reveal,点击 Help → Show Reveal Library in Finder;

这里写图片描述

3,将Reveal.framework 拖入打开的Xcode工程.并点击完成;

这里写图片描述

4,点击Build Phases 然后从Link Binary With Libraries 删除Reveal.framework;

从Link Binary With Libraries 删除Reveal.framework

5, 然后选中Build Settings 在搜索栏中输入 Other Linker Flags。选中Other Linker Flags

在Other Linker Flags中输入下面代码 : -ObjC -lz -framework Reveal

配置 Other Linker Flags

6,运行模拟器,打开Reveal,链接模拟器。

链接模拟器

到此大功告成。接下来你就可以通过Reveal 对你的界面进行debug了

效果

6. 调试工具集:FLEX

FLEX是Flipboard开源的一系列在应用中调试的工具集。FLEX以第三方库的形式集成在应用中,使用时将类库加到工程中,然后 通过调用[[FLEXManager sharedManager] showExplorer]; 就可显示出用于调试的工具栏进行调试。

它提供的功能如下:

  • 查看、修改views
  • 查看任何对象的属性
  • 动态的修改属性
  • 动态的调用实例方法和类方法
  • 查看网络请求过程
  • 添加模拟的键盘快捷键
  • 查看系统日志
  • 从堆中获取任何对象
  • 查看沙盒中的文件
  • 查看文件系统中的SQLite/Realm数据库
  • 在模拟器中触发3D touch
  • 查看你应用中所有的类
  • 快速获取常用的类,例如[UIApplication sharedApplication], the app delegate, the root view controller on the key window, and more.
  • 动态的查看NSUserDefaults里面的值

简直吊炸天。当你将FLEX集成到你项目中时就会认识到它的威力。

结语

上面介绍了六种调试方法,开发时可以根据具体情况选用最合适的调试方法。

本文作者:佚名

来源:51CTO

时间: 2024-09-27 09:28:34

iOS高效调试的相关文章

iOS崩溃调试

在iOS开发调试过程中以及上线之后,程序经常会出现崩溃的问题.简单的崩溃还好说,复杂的崩溃就需要我们通过解析Crash文件来分析了,解析Crash文件在iOS开发中是比较常见的. 现在网上有很多关于解析崩溃信息的博客,但是大多质量参差不齐,或者有些细节没有注意到.今天写一篇博客总结一下我对崩溃调试的使用和技巧,如果有哪些错误或遗漏,还请指点,谢谢! 获取崩溃信息 在iOS中获取崩溃信息的方式有很多,比较常见的是使用友盟.百度等第三方分析工具,或者自己收集崩溃信息并上传公司服务器.下面列举一些我们

iOS崩溃调试的使用和技巧总结

 每日更新关注:http://weibo.com/hanjunqiang  新浪微博 在iOS开发调试过程中以及上线之后,程序经常会出现崩溃的问题.简单的崩溃还好说,复杂的崩溃就需要我们通过解析Crash文件来分析了,解析Crash文件在iOS开发中是比较常见的. 现在网上有很多关于解析崩溃信息的博客,但是大多质量参差不齐,或者有些细节没有注意到.今天写一篇博客总结一下我对崩溃调试的使用和技巧,如果有哪些错误或遗漏,还请指点,谢谢! 获取崩溃信息 在iOS中获取崩溃信息的方式有很多,比较常见的是

我的女神——简洁实用的iOS代码调试框架

我的女神--简洁实用的iOS代码调试框架 一.引言         这篇博客的起源是接手了公司的一个已经完成的项目,来做代码优化,项目工程很大,并且引入了很多公司内部的SDK,要搞清楚公司内部的这套框架,的确不是件容易的事,并且由于这个项目是多人开发的,在调试阶段会打印出巨量的调试信息,使得浏览有用信息变的十分困难,更加恐怖的是,很多信息是SDK中的调试打印,将这些都进行注销是非常费劲甚至不可能的事,于是便有了这样一些需求:首先,我需要清楚了解各个controller之间的跳转关系,需要快速的弄

配合LLDB调试器进行iOS代码调试

配合LLDB调试器进行iOS代码调试         在一款完整iOS移动应用的开发中,代码的调试和编写占着同等重要的地位.Xcode默认使用LLDB作为代码调试器,LLDB功能丰富且强大,恰当的使用它,可以帮助开发者事半功倍的完成代码调试的工作. 1.expression代码执行指令         关于LLDB调试器,最常用的指令应该是p与po了,开发者常用这两个命令来进行对象的打印操作,p会打印出对象地址和类型,po则会额外打印出对象的值得内容,实际上,这两个命令都是expression相

IOS Xcode调试常用命令和断点整理_IOS

IOS Xcode调试常用命令和断点 Xcode 中的调试技巧与我们的日常开发息息相关,而这些调试技巧在我们解决Bug时,常常有事半功倍的作用,经常会用到的有各种断点 和 命令.而这些调试技巧也经常会在面试中问到,所以不知道的就来看看吧. 调试命令 在上图中,右侧绿色区域就是Log 输出区,在 Log 输出区可以使用一些命令,来辅助调试. 那有哪些调试命令呢? 想要看所有的调试命令,可以在上图的右侧区域输入help,就会列出所有的调试命令. 本文就介绍几个使用频率比较高的,其他就查看后,自行了解

iOS高效编程秘诀—坚持编程习惯

资料源于网络 习惯会影响一个人做事的方式,也会直接影响效率.我经常在项目完成后自我总结,有哪些做得好的,有哪些做得不好的?然后把一些好的流程记录下来,并且重新运用回编程中.那些能够坚持去做的流程,就变成了我的编程习惯,这些良好的习惯就成就了我高效的编程效率! 一.轻文档先行 什么叫轻文档?其实轻文档指的是不需要按照标准的软件工程知识来编写需求分析,架构设计,模块设计,流程图时序图等文档,而是采用比较自由的方式,把你要做的事情,还有做事情的步骤描述清楚的文档.这样的文档不需要限制格式,甚至你可以手

10款iOS高效开发必备的Objective-C类库

因为iOS SDK相对比较底层,所以开发者就得受累多做一些体力活.不过幸运的是,有很多第三方的类库可以用来简化很多不必要的工作.经过作者团队的慎重讨论,他们 评选出了10款能够极大提高iOS开发效率的类库,根据原文作者的评价来看,基本上有了这10款工具,做iOS开发就真的跟泡Cocoa一样了. MBProgressHUD--进展指示符库 苹果的应用程序一般都会用一种优雅的,半透明的进度显示效果,不过这个API是不公开的,因此你要是用了,很可能被清除出AppStore.而 MBProgressHU

Visual Studio Code 支持 iOS Web 应用调试

微软JavaScript Diagnostics项目经理Kenneth Auchenberg在一篇文章中写道,有一个新的Visual Studio Code扩展,允许开发人员直接在他们的Mac和Windows编辑器上调试在iOS设备上运行的JavaScript Web应用和网站. Auchenberg解释说,以前,调试iOS Web应用需要在Mac上运行Safari Web查看器,或者使用一个专用的跨浏览器兼容性检查器,如BrowserStack.新的Visual Studio Code扩展"i

iOS中崩溃调试的使用和技巧总结 韩俊强的博客

 每日更新关注:http://weibo.com/hanjunqiang  新浪微博 在iOS开发调试过程中以及上线之后,程序经常会出现崩溃的问题.简单的崩溃还好说,复杂的崩溃就需要我们通过解析Crash文件来分析了,解析Crash文件在iOS开发中是比较常见的. 现在网上有很多关于解析崩溃信息的博客,但是大多质量参差不齐,或者有些细节没有注意到.今天写一篇博客总结一下我对崩溃调试的使用和技巧,如果有哪些错误或遗漏,还请指点,谢谢! 获取崩溃信息 在iOS中获取崩溃信息的方式有很多,比较常见的是