Android Studio 学习之 Debug 调试

前言

正所谓,工欲善其事必先利其器,对于一个程序员来说,IDE就是我们器啊。IDE掌控的越熟悉,工作效率就越高(划水摸鱼的时间更多),所以要想效果更高(摸更多的鱼),就要好好学习如何使用IDE。

作为一个Android开发是无疑是幸福的,背靠Google爸爸,加上JetBrain的加持(JB大法好),所以就有了最完美的(不接受反驳)IDE—Android Studio(下文都以AS简称),就是有点吃内存哈😁,当然在16G内存的MBP上这些都不是事。虽然做了3年的Android开发,对于AS一直都是只用到一些最基础的操作,很多方便的技巧都没用到,远远没有发挥它的最大优势,所以决定从头好好学习一下如何最大化使用AS

正题

作为一个程序员,Debug调试技能是必不可少的,正好AS也为我们提供了强大的Debug功能。所以我们今天就来好好学习一下AS为我们提供的调试功能。

基于Android Studio 3.6.2学习。

开启调试

我们先来看看工具栏上面的图标:

下面一一解释图片中标注按钮(123568虽然不属于debug相关知识,顺带说一下):

  1. Run按钮:App已经运行,显示该图标,点击重新运行AppApp没有运行,该图片显示为绿色三角形。
  2. Apply Change and Restart Activity按钮: 通过重启Activity但不重启应用来应用资源和代码更改。通常用于修改了代码或资源文件。
  3. Apply Code Changes按钮: 尝试仅应用代码更改而不重启任何内容。通常用于只修改了代码,没有修改任何资源。
  4. Debug按钮: 开启Debug模式。
  5. Coverage按钮: 待摸索(知道的大佬,告诉我一下)。
  6. Profile按钮: 后面会单独出一篇文章讲解该功能。
  7. Attach debugger to Android process按钮: App已经运行中,点击该按钮,选择需要调试的进程即可。
  8. Stop按钮: 停止运行App

开始调试

当我们进入调试模式时,AS底部会显示Debug窗口,如果 Debug 窗口未打开,请依次选择 View > Tool Windows > Debug。下面我们先来看一张Debug窗口的总览:

我把整个窗口分为多个区域,

  • 菜单显示控制区
  • 1区断点管理区
  • 2区单步调试区
  • 3区堆栈帧线程区
  • 4区对象变量观察区

下面一一讲解。

菜单显示控制区

首先说一下最左边的菜单显示控制区,点击按钮,会弹窗菜单,勾上就代表该菜单要显示,图片中勾上所有的菜单了,所以在右边就能看到对应的菜单,如果取消那个菜单,右边对应的菜单也会隐藏。这个菜单显示大家可以跟自己需求选择。

重点来了!!!

1区断点管理区

竖向依次为:

  1. Return Android Debugger: 重新进入debug模式(App不会重新运行)
  2. Resume Program: 跳到下个断点。
  3. Pause Program: 暂停运行
  4. Stop Debugger: 停止断点模式
  5. View Breadpoints: 查看所有断点(后面会单独讲解)
  6. Mute Breadpoints: 开启\禁用所有断点
  7. Get Thread Dump: 获取线程Dump,点击会进入线程Dump界面(后面)
  8. Setting: 对一些菜单的显示控制
  9. Pin Tab: 多个程序调试时,固定Tab。作用摸索ing...

下面找重点的来讲解一下:

View Breadpoints:

还是先上图

断点展示区:

展示了所有有断点地方,在这里我们可以快速删除不需要的断点,增加程序运行速度。当然我们还可以添加我们关心的异常,就是常说的异常断点,比如NullPointerException,点击左上角➕,弹出菜单(如下图),大家可以根据自己的需求去选择不同的类型,这里我们选择Java Exception Breakpoints,然后在搜索框中输入 NullPointerException,会模糊匹配,然后选择NullPointerException就可以加入断点展示区了。

这样当我们代码出现空指针异常的时候,就会断点定位到发生异常的位置,非常方便。当时大家还可以添加其他种类的异常。

菜单设置区:

这个菜单可以点击左侧的断点管理区的View Breakpoints,还可以右键打断点的红点(如下图)

  1. Enable: 是否开启该断点。

  2. Suspend: 默认情况下,Android 系统会在其访问您分配给观察点的内存块时暂停应用进程。后面All表示暂停所有线程,Thread代表暂停当前线程。可以取消选择此选项,当你取消的时候红色断点会变成黄色,上图可以看到。

  3. Condition: 这个非常有用,就是常说的条件断点。一般用在循环里面,比如一个for循环,当i=8的时候,执行某个操作,难道你要循环一遍遍走吗?(我之前就是这么干的😂),其实可以直接在condition里面设置条件,如下图显示

可以看到我们`condition`增加条件的时候,红色断点下面多了个小问号,`num`也直接变成8,不用一步步循环到8了。
  1. 'Breakpoint hit' message: 勾上会输出Breakpoint hit

  2. Stack trace: 勾上会输出堆栈信息。

  3. Evaluate and log: 常说的日志断点,我们一般喜欢通过写代码打log来观察变量的变化,然后再删掉;这样一是麻烦,二是如果忘记,影响代码的美观性。这时,你就需要日志断点,如下图

这样我们就可以打印我们想看的变量了。
  1. Remove once hit: 就是停一次就移除,这样我们临时打的断点就不存在忘记取消的问题了。

重重重点来了!!!

2区单步调试区

Debug窗口上方只给出部分单步调试按钮,不过,我们平时用也够了。为了展示AS全部的单步调试按钮,我对run菜单下面的单步调试按钮进行讲解,如下图

Step Over(F8): 单步跳过,要前进到下一行代码(而不进入方法),如果方法内部有断点,会暂停。

Force Step Over: 不论方法中是否有断点,都会直接执行完方法所在代码行的下一步,不会在断点处暂停

Step Into(F7): 单步跳入,如果断点包含子方法则进入方法(不会进入官方类库的方法)。

Force Step Into: 强制单步跳入,在Step Info的基础上能进入任何方法。

Smart Step Info: 断点处包含两个或者以上方法链式调用,可以选择进入那个方法,包括匿名内部类,lambda表达式也可以,看下图。

这时你可以点击get或者getAccessToken方法内部进行调试。

Step Out(⇧F8): 单步跳出,与单步跳入相对,要前进到当前方法之外的下一行。

Run to Cursor: 执行到光标出(中途没有断点)。

Force Run to Cursor: 强制执行到光标出(无论有无断点)。

Drop Frame: 点击该按钮后,你将返回到当前方法的调用处重新执行,并且所有上下文变量的值也回到那个时候。只要调用链中还有上级方法,可以跳到其中的任何一个方法。

Evaluate Expression: 可以输入任何符合语法的计算表达式,包括变量,方法等调用。

  • 计算表达式
  • 方法调用

3区堆栈帧线程区

3区包含FramesThreadsFrames可以检查导致遇到当前断点的堆栈帧,和后面4区查看变量有关联。Threads展示当前进程的所有线程。这个区域我用的很少,更多作用待我摸索,对这个区域玩的6的大佬,可以在评论区分享一下。

4区对象变量观察区

这个区域我们平时也用的非常多,我们需要观察的一些变量值,都在这个区域观察。 相信大家都遇到过,我们写好代码,需要根据接口返回的状态进行不同的操作,但是状态永远只会有一种,我们怎么调试每一种状态,我们的代码业务逻辑走的是对的呢?我之前都是强行写一行代码改状态,然后再删掉(真的很low😂)。现在我们可以用setValue这个功能来改变变量的值了,和上面的Evaluate改变值类似。

还有有时变量特别多,我们只需要观察某一个变量的值时,可以用Add Watches

Google官网也给我们提供了很多更详细的调试技巧,大家有时间可以看一下。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容