idea从零到精通04之程序调试debug

Posted 编程界明世隐

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了idea从零到精通04之程序调试debug相关的知识,希望对你有一定的参考价值。

作者简介

作者名:编程界明世隐
简介:CSDN博客专家,从事软件开发多年,精通Java、javascript,博主也是从零开始一步步把学习成长、深知学习和积累的重要性,喜欢跟广大ADC一起打野升级,欢迎您关注,期待与您一起学习、成长、起飞!

引言

我本来是一直用eclipse和myeclipse的老程序员了,很多我的粉丝小伙伴都说他们要用idea,问我怎么不用idea,其实明哥觉得用啥开发工具都不是重点,重点是要跟着明哥多学Java知识、多练习,但是作为一个宠粉的人,我怎么能拒绝粉丝的要求呢,于是我偷偷的去学习了一波(拿来吧你),然后就写了这个系列,希望小伙伴们能有所收获,明哥会努力更新的。

导航

✪ idea从零到精通目录索引
◄上一篇  03.idea快捷键详述
►下一篇  05.程序调试debug

热门专栏推荐

(1).Java小游戏(俄罗斯方块、飞机大战、植物大战僵尸等)
(2).JavaWeb项目实战(图书管理、在线考试、宿舍管理等)
(3).JavaScript精彩实例(飞机大战、扫雷、贪吃蛇、验证码等)
(4).Java小白入门200例
(5).从零学Java、趣学Java
(6).Idea从零到精通

视频讲解

idea从零到精通(努力更新中。。。)

一、概述

在开发过程中,经常会发现一些错误,往往很多错误是我们无法一眼看出问题的,这时候需要Debug来追踪代码的运行流程、查看运行过程中各种变量的变化,从这些去分析程序为什么会发生错误,能够大大的提供我们的开发效率。

二、idea如何启动调试

  1. 在代码中打上断点

  2. 以debug模式运行代码

  3. 自动进入调试模式

三、调试窗口介绍

  1. 服务区
  2. 方法调用栈
  3. 调试按钮区
  4. 变量查看区

四、基本用法&快捷键

  1. 调试按钮
图标名称快捷键描述
显示执行点Alt + F10如果你的光标在其它行或其它页面,点击这个按钮可跳转到当前代码执行的行。
步过F8步过,一行一行地往下走,如果这一行上有方法不会进入方法。
步入F7如果当前行有方法,可以进入方法内部,进入的是自定义的方法,不会进入官方类库的方法。
强制步入Alt + Shift + F7如果当前行有方法,可以进入方法内部,可以进入官方类库的方法。
步出Alt + F10从步入的方法内退出到方法调用处,此时方法已执行完毕。
回退断点Shift + F8回退断点。
运行到光标处Alt + F9你可以将光标定位到你需要查看的那一行,然后使用这个功能,代码会运行至光标行,而不需要打断点。
    计算表达式Alt + F8如果你的光标在其它行或其它页面,点击这个按钮可跳转到当前代码执行的行。
  1. 服务按钮
图标名称快捷键描述
重新运行程序Ctrl+ F5会关闭服务后重新启动程序。
恢复程序F9程序继续执行直到碰到断点,如果没有碰到断点则执行完成程序。
暂停程序目前还没用过。
关闭程序Ctrl + F2关闭正在调试的程序。
查看所有断点Ctrl + Shift + F8显示所有的断点。
断点失效把所有的断点设置为失效状态。

五、变量查看

在Debug过程中,跟踪查看变量的变化是非常必要的。

  1. 在IDEA中,参数所在行后面会显示当前变量的值

  2. 鼠标悬停在变量上面,会显示变量的值

  3. 在Variables里查看,这里显示当前方法里的所有变量。

  4. 在Watches里,点击New Watch,输入需要查看的变量。
    点击这里的“+”号

    输入要查看的变量名,敲回车!

    显示变量的值如下:

六、计算表达式

通过如下图标,可以计算某个表达式的值或者设置变量值。

  1. 计算表达式的值。
    此时a的值是10的,如果我输入a*10,计算出100
  2. 设置变量值
    将变量a设置为100.

    点击Evaluate后,a变成100了,这个在调试过程中很有用,有时候我们想验证什么数据的时候就可以这样用。

七、断点条件设置

通过设置断点条件,在满足条件时,才停在断点处,否则直接运行,常见使用在循环内。

上例for循环中,打了一个断点,如果调试则断点要被执行10次,即 i==0 到 i==9都要进断点,特别是有时候多层循环,循环次数还多的情况就很麻烦,于是就可以设置条件。

  1. 在断点处右键。

    Condition 写入boolean条件,比如这里填入 i3,意思就是第4次循环才进入断点,在点击Done。

    此时断点是带一个问号的。

    启动调试此程序,此时只有 i
    3 才进断点来调试。
  2. 点开所有的断点,选择对应的断点,设定条件,跟上一个是一样的。
  3. 异常断点,通过设置异常断点,在程序中出现需要拦截的异常时,会自动定位到异常行。


    创建了一个数组越界异常。
    编写以下代码(故意写成会数组越界的)
/**
 * @author 编程界明世隐
 * @title: Test2
 * @projectName debug
 * @description: 123
 * @date 2021/10/9 14:28
 */
public class Test3 {

  public static void main(String[] args) {
    int[] arr = {1,3,5,7,9};
    for (int i=0;i<=5;i++){
      System.out.println(arr[i]);
    }
  }
}

我本身是没有打断点的,我debug一下。

八、断点回退

断点回退,其实就是回退到上一个方法调用的开始处,如下代码:

import java.sql.SQLOutput;
import java.util.HashMap;
import java.util.Map;
import org.omg.Messaging.SyncScopeHelper;

/**
 * @author 编程界明世隐
 * @title: Test1
 * @projectName debug
 * @description: 123
 * @date 2021/10/9 12:20
 */
public class Test4 {

  public static void main(String[] args) {
    Map param = new HashMap();
    param.put("name","编程界明世隐");
    changeName(param);
    System.out.println(param.get("name"));

  }

  public  static  void  changeName(Map m){
    m.put("name","编程界明世隐123");
    System.out.println(m.get("name"));
  }
}

在方法内部打断点,并进入调试

有时候如果我想重新调试这个方法,我只需点击回退按钮既可,以下按钮:

此时程序会回到这个方法的入口处。

不需要重新启动debug,提供了方便。

注意点:
调试过程中某些已经修改的数据值、数据状态是无法回退的,比如如对象、集合、更新了数据库数据等等。
比如,当我们运行到25行,此时name的值已经被修改过了

这时候点击回退,此时回到了方法开始处,但Map里面对应的值已经被修改了。

九、调试中断

有些时候,我们看到传入的参数有误后,不想走后面的流程了,怎么中断这次请求呢,比如后面涉及到数据库的操作、对外部接口的调用等,我之前用eclipse的时候就只能关闭服务了。

import java.sql.SQLOutput;
import java.util.HashMap;
import java.util.Map;
import org.omg.Messaging.SyncScopeHelper;

/**
 * @author 编程界明世隐
 * @title: Test1
 * @projectName debug
 * @description: 123
 * @date 2021/10/9 12:20
 */
public class Test4 {

  public static void main(String[] args) {
    Map param = new HashMap();
    param.put("name","编程界明世隐");
    changeName(param);
    System.out.println("打印1:"+param.get("name"));

  }

  public  static  void  changeName(Map m){
    m.put("name","编程界明世隐123");
    System.out.println("打印2:"+m.get("name"));
  }
}

正常调试的话会打印:

打印2:编程界明世隐123
打印1:编程界明世隐123

如果我们调试到25行,让25行所在方法的代码不继续执行

可以在方法调用栈找到当前方法,右键选择Force Return

此时会发现方法被跳过执行完了,

将程序跑完,结果如下:

打印1:编程界明世隐123

这就表示changeName 里面的打印方法被跳过了,这就是debug中断。

小结

这节总结了“ 程序调试debug ”,希望能对大家有所帮助,请各位小伙伴帮忙 【点赞】+【收藏】+ 【评论区打卡】, 如果有兴趣跟小明哥一起学习Java的,【关注一波】不迷路哦。

评论区打卡一波让我知道你,明哥会持续关注你的学习进度哦!

导航

✪ idea从零到精通目录索引
◄上一篇  03.idea快捷键详述
►下一篇  05.程序调试debug

热门专栏推荐

(1).Java小游戏(俄罗斯方块、飞机大战、植物大战僵尸等)
(2).JavaWeb项目实战(图书管理、在线考试、宿舍管理等)
(3).JavaScript精彩实例(飞机大战、扫雷、贪吃蛇、验证码等)
(4).Java小白入门200例
(5).从零学Java、趣学Java
(6).Idea从零到精通

以上是关于idea从零到精通04之程序调试debug的主要内容,如果未能解决你的问题,请参考以下文章

idea从零到精通(09)之修改代码无需重启Tomcat(热启动)

IDEA从零到精通(36)之快速返回上次代码的位置

IDEA从零到精通(17)之IDEA中用Maven创建springboot项目

idea从零到精通08之IDEA常用插件提升开发效率

IDEA从零到精通(16)之IDEA中用Spring Initializr创建springboot项目

IDEA从零到精通(21)之使用Maven clean发生错误Process terminated