在线排版不太好看,介意的读者可下载word下来看:https://download.csdn.net/download/xijinno1/87441301
IDEA下java程序的简单调试-System.out.println
首先本次进行调试的一个程序是实现从1累加到100的功能,是在IDEA下进行编写的。如图所示:
public class Demo {
public static void main(String[] args) {
int i; //用于做临时变量
int sum = 0; //用于存放累加的结果
for (i = 1; i <= 100; i++) {
sum += i;//每次循环进行的累加
// System.out.println("第“+i+”次循环,sum的值为 " + sum); // 输出
}
System.out.println("从1加到100的结果是:" + sum); // 输出
}
}
将其运行之后得到的结果如图所示:
![](https://img-blog.csdnimg.cn/img_convert/d2964128cac644a6a9ea764d18d906bf.png)
把
// System.out.println("第“+i+”次循环,sum的值为 " + sum); // 输出
语句取消掉注释之后再运行一次得到的结果如图所示:
![](https://img-blog.csdnimg.cn/img_convert/d4411b8680d84f3b8e1ee6a46dbf200f.png)
这里由于输出结果太多,所以只截取到了一部分。不过可以看到,在加了这个循环中的输出语句之后,就可以清楚的看到每次循环所经历的一个过程,所得到的结果。
当然不仅只能这样来进行观察程序的运行,我们可以使用IDEA的Debug功能。在编程的时候使用Debug有很多的好处,比如说能够跟踪变量,可以看到变量值的变化。或者是能够迅速的找到程序中所出现的错误。
这种调试的方式能看到的信息比较少,操作也相对较多,下面叙述一下用断点的方式进行调试。
IDEA下java程序的简单调试-Debug
实例程序还是如下程序(实现从1累加到100):
public class Demo {
public static void main(String[] args) {
int i; //用于做临时变量
int sum = 0; //用于存放累加的结果
for (i = 1; i <= 100; i++) {
sum += i;//每次循环进行的累加
// System.out.println("第“+i+”次循环,sum的值为 " + sum); // 输出
}
System.out.println("从1加到100的结果是:" + sum); // 输出
}
}
首先要设置断点
(方法:在一个有效的代码行左边的空白处,行号后面,如下图红框处点击),设置成功后如图所示:
![](https://img-blog.csdnimg.cn/img_convert/cfa3308d4d904a119d7e2445dd1e85ce.png)
断点表示当手动Debug来运行程序时,程序会在断点之前停止运行。
启动Debug
手动Debug有如下几种
方法1:
快捷键shift+F9
方法2:
点击如下图的图标
![](https://img-blog.csdnimg.cn/img_convert/5b3883fc1fd34c6a9adb8f4ee3f48399.png)
或者,在下方找到调试窗口后选择调试图标,如下图
![](https://img-blog.csdnimg.cn/img_convert/98a59916460042239f423eb7c9f9214c.png)
方法3:
菜单栏依次点击 运行 -> 调试 ...,如下图
![](https://img-blog.csdnimg.cn/img_convert/67d0c0a732e041f19d68e58d47622b59.png)
启动Debug之后会出现一个Debug的调试窗口,如图所示:
![](https://img-blog.csdnimg.cn/img_convert/ac4d6246853046ffb01254f59a1d078e.png)
注意:有时候可能会碰到点击调试按钮但是当前调试界面却并不是想要调试的文件的情况,你需要把当前的执行窗口切换过来:
![](https://img-blog.csdnimg.cn/img_convert/80270b0eb26d46ef9989f5ee54e65a7e.png)
或者直接在要调试的文件左侧点击调试,操作如下图:
![](https://img-blog.csdnimg.cn/img_convert/2cd30d05dea547df8c27f76e123512b6.png)
一些调试按钮和快捷键
当点击
![](https://img-blog.csdnimg.cn/img_convert/5885cd70846b4057bfb301837669d830.png)
(快捷键是F7)的时候会执行代码的下一行,如下图所示:
![](https://img-blog.csdnimg.cn/img_convert/10d98271c8cd471d9b9d130ac77de810.png)
右边显示的sum=0就是我们点击
![](https://img-blog.csdnimg.cn/img_convert/90523e43bc1443bbb4191e4de7e549a4.png)
(快捷键是F7)就能得到的下一行代码执行的内容,右边这个方框也就是变量值的显示区域。同时代码行的右边也能够看到变量的值,这里sum的初始值为0,如下图所示:
![](https://img-blog.csdnimg.cn/img_convert/f0c02ee5d1c64cd9ac0e48c4fdb8a8c8.png)
再次点击
![](https://img-blog.csdnimg.cn/img_convert/58608fa532e34549b05f9d5e67f44e93.png)
(快捷键是F7),进入到循环中,i的初始值为1,如图所示:
![](https://img-blog.csdnimg.cn/img_convert/3b953969b9c64724b0af2cf60cfd37e6.png)
再点击一次
![](https://img-blog.csdnimg.cn/img_convert/6634e7c3806e49e68fe0aacf954fb0b8.png)
(快捷键是F7)就能够得到第一次循环后sum的值为1,如图所示:
![](https://img-blog.csdnimg.cn/img_convert/813e238a9e844f11a9e8366d1eb474ed.png)
代码行处也是显示了变量的值,如图所示:
![](https://img-blog.csdnimg.cn/img_convert/531a09bca47944a5900bddeaaf16a488.png)
值得一提的是,每运行到一行程序时代码行都会有这种与其他代码行不同颜色的提示。同时main后面的数字也是告诉我们执行到哪一行。如图所示:
![](https://img-blog.csdnimg.cn/img_convert/d2fad8c0d53c4ce3807039746956e767.png)
这里就是表示执行到main方法得第5行。
左下红色框所在位置显示的是当前压栈的方法,跟栈区运行一样,先进后出,最先压栈的在最下面,最上面的最后压栈,也就是最后一次加载进栈区的方法,而方法名前面显示的数字就是当前调试进度所在的行数。
而如果要直接运行完整个程序就可以点击左边的
![](https://img-blog.csdnimg.cn/img_convert/19f0de76bd7e4a5d8944cd2e3b21e5fa.png)
(快捷键是F9),就可以得到运行后的结果,结果是在
![](https://img-blog.csdnimg.cn/img_convert/5bdd3e262c5742b39553cd1e179fcf6a.png)
(中文版
![](https://img-blog.csdnimg.cn/img_convert/10e11cd60add4e41b8f48f174375bcb5.png)
) 里面进行查看。如果想要重新Debug,是点击
![](https://img-blog.csdnimg.cn/img_convert/33b30f79ed1d4b75973f1fa5a38aeb81.png)
(快捷键是Ctrl+F5)。当然要结束Debug,可以点击
![](https://img-blog.csdnimg.cn/img_convert/2bf5ba7189134d7e995ea7d47a995c97.png)
(快捷键是ctrl+F2)。 如图所示:
![](https://img-blog.csdnimg.cn/img_convert/38bc2f8ff7f341c9941bf7492e371bb2.png)
按下F9得到运行得结果,在Console(控制台)中查看,如图所示:
![](https://img-blog.csdnimg.cn/img_convert/e6adec13e4764c8ab0bd68db3896d257.png)
接下来对程序进一步的改进,将循环体放入到一个方法中,整个代码如下:
public class Demo {
public static void main(String[] args) {
sum(); // 调用方法
}
// 定义一个名为sum的方法
public static void sum() {
int i; //用于做临时变量
int sum = 0; //用于存放累加的结果
for (i = 1; i <= 100; i++) {
sum += i;//每次循环进行的累加
System.out.println("第“+i+”次循环,sum的值为 " + sum); // 输出
}
System.out.println("从1加到100的结果是:" + sum); // 输出
}
}
将上述代码放入idea中,同时在第3行打一个断点,结果如图所示:
![](https://img-blog.csdnimg.cn/img_convert/110b2d7190694976b20affae86970e87.png)
手动启动Debug后,会出现下图现象(代码运行到main方法的第3行停住):
![](https://img-blog.csdnimg.cn/img_convert/3319e7262d9b42b7b87b417a70604f69.png)
这个时候如果点击
![](https://img-blog.csdnimg.cn/img_convert/2a02fde1cdf74360b4bc73c20ae038a0.png)
(快捷键是F8),就会直接往下运行,因为
![](https://img-blog.csdnimg.cn/img_convert/74c0c33bdf1a489a95b01de23719f128.png)
(快捷键是F8)表示的是步过,就是直接往下走,如果这一行上有方法不会进入到方法体当中,如下图所示:
![](https://img-blog.csdnimg.cn/img_convert/f2a3f8f441804cdaa368f40a972cbc35.png)
点击一次
![](https://img-blog.csdnimg.cn/img_convert/8b6b6f231fc44e2bbddb92ee72c39b50.png)
(快捷键是F8)后,直接跳过方法运行到第4行,并且能够直接从Console(控制台)中看到方法运行的结果,如下图所示:
![](https://img-blog.csdnimg.cn/img_convert/9fa5b06834564439b3a361e52f12094a.png)
点击第二次
![](https://img-blog.csdnimg.cn/img_convert/d1207bdf160d44328a7597f00c076641.png)
(快捷键是F8) 后,直接结束,如下图所示;
![](https://img-blog.csdnimg.cn/img_convert/77154dc9f66f4ec08b8a5c0d0053561d.png)
而如果使用的是
![](https://img-blog.csdnimg.cn/img_convert/47cc82828d3343fca0e544be9304fc88.png)
(快捷键F7)就能够进入到方法内部,因为
![](https://img-blog.csdnimg.cn/img_convert/a058d7c6d12a4c899b7d57c455904877.png)
(快捷键F7)表示的是步入,如果当前行有方法就能够直接进入到方法内部,不过只能进入到自行定义的方法中,不能进入到官方类库中的方法。如下图所示:
![](https://img-blog.csdnimg.cn/img_convert/830c546363e849538b289082d9aa2a5b.png)
可以看到左下角的Debug框中也表示了进入到sum方法,运行到第9行。接下来继续点击
![](https://img-blog.csdnimg.cn/img_convert/f329fef623cd4698b292943ac4e8ab0a.png)
(快捷键F7)就和前面所讲的一样,反复进行循环,循环结束后,就得到运行结果,程序结束。
而如果在运行到方法中,想要跳出方法,直接将方法运行结束,就要点击
![](https://img-blog.csdnimg.cn/img_convert/3b55419503c245b5bbb17031d62cdce2.png)
(快捷键shift+F8),如下图所示:
![](https://img-blog.csdnimg.cn/img_convert/86ec3eca3dd449da91d7c893101afbad.png)
![](https://img-blog.csdnimg.cn/img_convert/052fd598c1d94e3c93fce2b97f864c2e.png)
(快捷键shift+F8)表示的是步出,就是从方法内部回到方法的调用处,如图所示(在方法体内点击
![](https://img-blog.csdnimg.cn/img_convert/c457033d5b034540a357ee5e1755d19c.png)
(快捷键shift+F8)之后就直接跳到了第4行 ):
![](https://img-blog.csdnimg.cn/img_convert/2437b4835ea54ab5946644e7a485396c.png)
小结
当在对java程序进行调试的时候,如果不要进入方法中查看,就可以直接使用
![](https://img-blog.csdnimg.cn/img_convert/a1855d1791d8448b903cbe2f64e9fbd9.png)
(快捷键是F8)步过进行查看。如果要进入方法中查看,就需要使用
![](https://img-blog.csdnimg.cn/img_convert/ffb039cfdae14c62b1a1018261362944.png)
(快捷键是F7)步入进行查看。在方法之中想要退出到方法调用处需要使用
![](https://img-blog.csdnimg.cn/img_convert/3efc6f9992454c9b9565f96657391b1e.png)
(快捷键是shift+F8)步出。
还有一个按钮是
![](https://img-blog.csdnimg.cn/img_convert/8a47a42438e94fed9ceba34a42f11e10.png)
(快捷键是Alt+F9),作用是debug时使程序到达光标所在的地方,注意,要程序可以到达的地方,否则程序不会停止在光标处。
![](https://img-blog.csdnimg.cn/img_convert/a009f48b6cda412681d671ce3b8dc477.png)
![](https://img-blog.csdnimg.cn/img_convert/6b4f57ec88ae4c38a1db9f6625088c5c.png)
![](https://img-blog.csdnimg.cn/img_convert/01d829e917da491da1d54d71d45cb0f8.png)
(快捷键是shift+F9): 启动Debug
![](https://img-blog.csdnimg.cn/img_convert/39020e53bff64ae1a3d1c2a1e9761181.png)
(快捷键是Ctrl+F5):重新Debug
![](https://img-blog.csdnimg.cn/img_convert/9fb8351133564954b74039148d2f54d2.png)
(快捷键是F9):直接运行完整个程序,
![](https://img-blog.csdnimg.cn/img_convert/300b39069add471e9a18d8743cb618bb.png)
(快捷键是ctrl+F2) :结束Debug
![](https://img-blog.csdnimg.cn/img_convert/a9fcbddbe155473ebc2d8289fd49b5f2.png)
(无快捷键) ,本文未实例演示:调试程序时,暂停程序运行
![](https://img-blog.csdnimg.cn/img_convert/64a6440340c241bda9550cc426bc5a69.png)
(快捷键是ctrl+shift+F8) ,本文未实例演示:查看程序中的断点
![](https://img-blog.csdnimg.cn/img_convert/985569af47d347c1900ef99a4819cb4d.png)
(无快捷键) ,本文未实例演示:屏蔽所有断点,即debug时,即使有断点,程序也不会命中断点。
![](https://img-blog.csdnimg.cn/img_convert/83ed42c001514a9796638bbb7b3e5582.png)
![](https://img-blog.csdnimg.cn/img_convert/112ed72ec3b843c38e3ec8e02dd29228.png)
(快捷键是F8):表示的是步过,直接往下走,如果这一行上有方法不会进入到方法体当中
![](https://img-blog.csdnimg.cn/img_convert/96e8dca6ace549588369240f5be77a3e.png)
(快捷键是F7): 执行代码的下一行,如果这一行上有方法会进入到方法体当中
![](https://img-blog.csdnimg.cn/img_convert/0418011a76f84feca573a7655a8ad5c1.png)
(快捷键shift+F8):表示的是步出,从方法内部回到方法的调用处
![](https://img-blog.csdnimg.cn/img_convert/3ae45843c13844dc9db70e4d937643d8.png)
(快捷键是Alt+F9):作用是debug时使程序到达光标所在的地方