亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術(shù)文章
文章詳情頁

Java根據(jù)控制臺實現(xiàn)定位異常

瀏覽:31日期:2022-09-01 08:37:26

異常堆棧作為我們平時定位問題的最重要手段,為我們解決問題提供了很大幫助。但是我們可能都有這樣的習(xí)慣就是看到一段異常,尤其是異常堆棧很多,層次很深的時候。就感覺很擔(dān)心害怕,匆匆掃描一眼就開始猜問題應(yīng)該如何如何,然后不斷的根據(jù)猜測去調(diào)整代碼,雖然也會 debug 但是還是浪費了不少的時間。

這是因為:

1.我們沒有認(rèn)認(rèn)真真的看異常堆棧信息;

2.堆棧太多,我們并不確定到底哪里導(dǎo)致了問題。

解決辦法就是:

1.知道異常堆棧產(chǎn)生的流程。

2.耐心的閱讀堆棧信息。

3.解決問題

1.異常產(chǎn)生流程:上面報錯,下面跟隨

舉個例子:我們有如下的測試代碼:

package com.bsx.test;public class TestException { public static void main(String[] args) { TestException exception = new TestException(); exception.m1(); } public void m1() { m2(); } public void m2() { m3(); } public void m3() { String name = null; System.out.println(name.length()); }}

執(zhí)行之后輸出結(jié)果如下:

Exception in thread 'main' java.lang.NullPointerExceptionat com.bsx.test.TestException.m3(TestException.java:22)at com.bsx.test.TestException.m2(TestException.java:17)at com.bsx.test.TestException.m1(TestException.java:13)at com.bsx.test.TestException.main(TestException.java:9)

我們可以看到,這個錯誤日志輸出的順序跟調(diào)用順序是相反的,為什么呢?

我們知道 java 的方法在執(zhí)行的時候是在虛擬機棧中執(zhí)行的,每執(zhí)行一個方法就會新建一個棧幀然后壓入到虛擬機棧中。這是一個后進(jìn)先出的結(jié)構(gòu),所以報錯的時候也是從被調(diào)用者最開始報錯,然后調(diào)用者依次報錯,所以打印錯誤時的順序也是報錯的位置在最上面,調(diào)用者依次向后排。

由此我們可以得出結(jié)論:上面報錯,下面跟隨。

2.讀懂報錯信息:尋找我們代碼報錯的位置

從上面的分析我們知道報錯位置在上面。

大部分情況下,最上方的報錯信息就是我們代碼出錯的位置。但是有時候最上方的日志并不是我們自己的代碼,那是因為我們的代碼調(diào)用了一些三方 jar 包的代碼。但是這并不影響我們?nèi)ザㄎ粏栴},我們還是根據(jù)上面報錯,下面跟隨來定位問題,那么真正報錯的位置還是在上面。那么我們只需要從上往下依次找我們自己的代碼即可。

第一個找到的我們的代碼位置就是我們代碼中引發(fā)報錯的位置。有時候有些報錯信息很明顯,我們可以根據(jù)報錯信息來直接定位到問題癥結(jié)。有時候報錯信息并不能很明確的指明報錯原因,這時候,我們就可以在這個精確的位置打上斷點來調(diào)試一下。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 欧美高清在线 | 麻豆19禁国产青草精品 | 美女黄视频在线 | 免费看成人毛片日本久久 | 97在线视频免费公开观看 | 国产一区二区三区在线视频 | 亚洲第五色综合网啪啪 | 538prom精品视频在放免费 | 一级看片 | 国产精品久久久久影院色老大 | 亚洲欧洲日产国码二区在线 | 尤物蜜芽福利国产污在线观看 | 日本三级香港三级人妇99视 | 国产久草视频 | 国产玖玖玖精品视频 | 欧美日一级 | 国产精品系列在线 | 99国产精品视频免费观看 | 国产在线观看一区精品 | 日韩成人在线观看视频 | 免费看真人a一级毛片 | 狠狠色丁香婷婷综合 | 99爱视频在线| 澳门一级特黄真人毛片 | 久久久综合结合狠狠狠97色 | 欧美巨乳在线观看 | 老师张开腿让我爽了一夜视频 | 一级爱| 一个人看的日本免费视频 | 免费人成综合在线视频 | 欧美在线视频精品 | 亚洲欧美在线视频免费 | 久久久国产一区二区三区丝袜 | 亚洲性免费 | 国产一区二区三区免费 | 国产在线欧美日韩一区二区 | 中国hd高清╳xxx | 亚洲福利视频一区二区三区 | 亚洲欧洲日韩在线 | 九九国产精品 | 欧美福利一区二区三区 |