av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

Java根據(jù)控制臺(tái)實(shí)現(xiàn)定位異常

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

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

這是因?yàn)椋?/p>

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

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

解決辦法就是:

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

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

3.解決問(wèn)題

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

舉個(gè)例子:我們有如下的測(cè)試代碼:

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)

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

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

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

2.讀懂報(bào)錯(cuò)信息:尋找我們代碼報(bào)錯(cuò)的位置

從上面的分析我們知道報(bào)錯(cuò)位置在上面。

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

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

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

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 中文字幕免费在线 | 成人精品视频 | 国产精品乱码一区二区三区 | 成人国产精品久久久网站 | 婷婷视频在线 | 91色网站 | 亚洲视频二区 | 国产视频一区二区在线观看 | 日韩免费视频一区二区 | 青青草在线观看视频 | 欧美做受 | 午夜成人影片 | 午夜www | 动漫av在线 | 精品国产91乱码一区二区三区 | 91亚洲一区 | 欧美精品在线播放 | 国产女人高潮视频 | 国产精品成人一区二区 | 就爱啪啪网 | 亚洲免费二区 | 影音先锋在线观看视频 | www.亚洲天堂 | 国产精品久久久久久99 | 97超碰资源站 | 亚洲成人欧美 | 国产成人免费在线观看 | 五月天婷婷在线观看 | 99亚洲精品| 国产精品入口66mio男同 | 欧美成人精品欧美一级乱黄 | 日韩中文在线视频 | 在线看91 | 欧美一区二区在线 | 91在线免费视频观看 | 亚洲一区二区在线播放 | 国产视频福利 | 男男成人高潮片免费网站 | 国产精品三级在线 | 日韩综合久久 | 久久99精品久久久久久琪琪 |