
java调试器(jdb)是一个命令行工具,用于调试java程序。当我们在jdb中使用step命令进行单步执行时,jdb会默认显示当前线程、方法名、行号以及字节码索引(bci),但并不会直接在控制台输出当前执行的源代码行内容。这对于习惯了ide中集成调试器(通常会高亮显示当前行)的用户来说,可能会造成困惑,因为他们期望看到即将执行的代码行。
例如,在示例代码中:
public class Main {
public static void main(String[] args) {
System.out.println("Hello world!"); // Line 3
System.out.println("Hello world! line 2"); // Line 4
System.out.println("Hello world! line 3"); // Line 5
}
}当程序在第3行暂停并执行step命令后,JDB的输出可能如下:
Step completed: "thread=main", Main.main(), line=4 bci=8
这表明程序已经执行完第3行,当前暂停在第4行,但并未显示第4行对应的源代码System.out.println("Hello world! line 2");。
为了在JDB调试过程中查看当前执行位置的源代码,我们需要结合使用list命令。list命令用于显示当前方法中指定行号附近的源代码。
list 命令的用法:
下面我们将通过一个完整的JDB调试会话,演示如何结合step和list命令来有效地进行源代码级别的调试。
1. 准备源代码
// Main.java
public class Main {
public static void main(String[] args) {
System.out.println("Hello world!"); // Line 3
System.out.println("Hello world! line 2"); // Line 4
System.out.println("Hello world! line 3"); // Line 5
}
}2. 编译源代码(包含调试信息)
为了让JDB能够获取到源代码行信息,编译时必须使用-g选项来生成调试信息。
javac -g Main.java
3. 启动JDB并调试
# 启动JDB jdb Main
JDB启动后,我们将设置一个断点,运行程序,并在步进时使用list命令。
Initializing jdb ...
> stop at Main.main # 在main方法入口设置断点
Deferring breakpoint Main.main.
It will be set after the class is loaded.
> run # 运行程序
run Main
Set uncaught java.lang.Throwable
Set deferred uncaught java.lang.Throwable
>
VM Started: Set deferred breakpoint Main.main
Breakpoint hit: "thread=main", Main.main(), line=3 bci=0 # 断点命中,当前在第3行
main[1] list # 第一次使用list,查看当前行及其附近代码
1 public class Main {
2 public static void main(String[] args) {
3 => System.out.println("Hello world!");
4 System.out.println("Hello world! line 2");
5 System.out.println("Hello world! line 3");
6 }
7 }
main[1] step # 单步执行,跳到下一行
Step completed: "thread=main", Main.main(), line=4 bci=8 # JDB显示已到第4行
main[1] list # 再次使用list,查看当前行及其附近代码
1 public class Main {
2 public static void main(String[] args) {
3 System.out.println("Hello world!");
4 => System.out.println("Hello world! line 2");
5 System.out.println("Hello world! line 3");
6 }
7 }
main[1] step # 继续单步执行
Step completed: "thread=main", Main.main(), line=5 bci=16 # JDB显示已到第5行
main[1] list # 再次使用list
1 public class Main {
2 public static void main(String[] args) {
3 System.out.println("Hello world!");
4 System.out.println("Hello world! line 2");
5 => System.out.println("Hello world! line 3");
6 }
7 }
main[1] quit # 退出JDB从上述示例中可以看到,每次执行step命令后,通过紧接着执行list命令,我们就能清晰地看到JDB当前暂停的源代码行,并且=>符号会明确指示当前执行的位置。
通过本文的介绍,我们了解到JDB在步进调试时不会自动显示源代码行,但这一问题可以通过巧妙地结合list命令来解决。掌握list命令的使用,并确保在编译时包含调试信息,将极大地提升JDB命令行调试的效率和便利性。虽然JDB在交互性上有所欠缺,但其作为Java开发工具包(JDK)的一部分,依然是进行底层Java程序调试的重要工具。
以上就是JDB调试技巧:如何在步进时显示源代码行的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号