博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iOS调试奇巧淫技(一)
阅读量:6908 次
发布时间:2019-06-27

本文共 1260 字,大约阅读时间需要 4 分钟。

你以为,你以为的就是你以为的吗?

这里写图片描述

  • 你以为你代码写的很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
你可能感兴趣的文章
MySQL事务隔离级别详解
查看>>
storm记录--3--Storm的基本概念
查看>>
×××灯marquee标签应用详解
查看>>
彻底弄懂css中单位px和em,rem的区别
查看>>
我的友情链接
查看>>
MapReduce的输出格式
查看>>
AD帐号属性灰色不能修改--解决办法
查看>>
当子页面关闭的时候动态刷新页面的局部
查看>>
javascript 去掉重复的值
查看>>
[置顶] jQuery基础学习(一)
查看>>
SIP Servlet 开篇
查看>>
我在IT中的那些转变
查看>>
用户管理 之 Linux 用户管理工具介绍
查看>>
UIScrollView 滚动视图
查看>>
vc 客户端服务器程序
查看>>
liquibase
查看>>
配置RADIUS客户端
查看>>
Java闭锁_CountDownLatch
查看>>
openstack I版的搭建八--
查看>>
发一道JS题,不看答案你会吗?
查看>>