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

2021/10/16 11:40:52

本文主要是介绍idea从零到精通04之程序调试debug,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

文章目录

  • 作者简介
  • 引言
  • 导航
  • 一、概述
  • 二、idea如何启动调试
  • 三、调试窗口介绍
  • 四、基本用法&快捷键
  • 五、变量查看
  • 六、计算表达式
  • 七、断点条件设置
  • 八、断点回退
  • 九、调试中断
  • 小结
  • 导航
  • 热门专栏推荐

作者简介

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

在这里插入图片描述

引言

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

导航

✪ idea从零到精通目录索引
◄上一篇  03.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快捷键详述
►下一篇待更新     

热门专栏推荐

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



这篇关于idea从零到精通04之程序调试debug的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程