iOS调试奇巧淫技(一)
来源:互联网 发布:windows 添加路由 编辑:程序博客网 时间:2024/06/14 16:30
你以为,你以为的就是你以为的吗?
- 你以为你代码写的很OK啦?
- 你以为你的是大牛啦?
- 你以为的就是你以为的吗?
- 你的代码经得起考验吗?(PS:爱经得起考验吗)
iOS调试的技巧很多,通过调试我们不仅可以迅速找到Bug的所在,更能优化代码,让你的你以为不再是你以为!
一、断点
普通断点
当运行时遇到断点会停止下来供程序员调试
我们清晰的看到此时的i依旧等于0,该函数在一个名为ViewController中
上图中有五个可选按钮
分别是取消断点按钮、继续执行一步按钮、步入按钮、步出按钮
条件断点
点击断点右键的Edit Breakpoint按钮
解释一下:
Condition后面的UILbel中我们可以写入条件语句 例如i==5,此时断点只会在i==5的时候断点作用才会生效
同样的我们可以在lgnore里面设置数字,表示忽略前面的执行次数,在数字+1时
才会生效。
当我们想看到哪个函数执行了多少次,可以在Action设置为Log Message,如下图所示的那样:
记住一定要把下面的对号打上呀
异常断点
注意这个断点感觉是最实用的
我们经常会遇到程序调试过程中崩溃,几万行甚至几十万行的代码,崩溃后就会跑到Mian函数中,根本不清楚
哪里出现问题,想加普通断点调试都不知道该往哪里加,如下图那样:
看到这个你是不是这样的表情:duang~一般的崩溃
此时我们就需要加到异常断点,加入办法如下:
这样我们遇到崩溃~~~
Dang~的XCode直接帮我们进入引起Crash的地方,方便进行修改
配置断点:根据使用性也加函数、类断点
通过配置断点我们可以精确到某个类或者某个方法中进行终端
具体做法是在Symobol中根据具体的需求加上相应的函数或者类
代码运行时间
我们完成一个项目后,进行调试,为了使软件流畅的最大化,有时候需要优化代码,这时候我们需要找到哪些
代码是耗时的,想办法优化算法或者另外开辟多线程,保证良好的用户体验。这时候就用到测时间的方法。
NSDate *startTime=[NSDate date];for (i=0; i<100000; i++) { NSLog(@"NSLog:%d次",i);}NSLog(@"Time is:%f",-[startTime timeIntervalSinceNow]);
建议在pch文件中可以定义一个宏变量,关于pch的用法
可以参考我的这篇博客
#define STARTTIME NSDate *startTime=[NSDate date];#define ENDTIME NSLog(@"Time: %f", -[startTime timeIntervalSinceNow]); STARTTIMEfor (i=0; i<100000; i++) { NSLog(@"NSLog:%d次",i);} ENDTIME
还有LLDB、Profile等东西需要细细总结,但因每天晚上要跑步就先到这里啦,明天找时间补充~~~ O(∩_∩)O
2 1
- iOS调试奇巧淫技(一)
- iOS调试奇巧淫技(二)之LLDB
- MTK 调试的奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- iOS开发的一些奇巧淫技
- 三色球问题
- 做高算平台,安装编译行业软件OpenFOAM的时候踩过坑,其中的一个。
- linux mint 17.3 安装cuda7.5 toolkit
- 求1加到n的发散思维方法
- 【CSS】前端笔试题总结
- iOS调试奇巧淫技(一)
- Trick(十二)——统计 label(序列)各个标签值出现的次数以及出现次数最多的标签
- oracle数据库问题
- ARM MMU工作原理剖析
- 《50 Android Hacks》学习心得一:延迟加载和布局重用
- golangStart fetch.go
- iOS -- pch文件介绍 及用法 - $(SRCROOT)/工程名/pch文件名.pch -- <一>
- iOS开发~CocoaPods使用详细说明
- 使用docker 构建一个web应用