一. 前言
每一個程序猿在曲迂奮進的成神路上,都會遇到一些大大小小的妖魔和臭蟲阻礙,可以說這些bug會伴隨著我們整個的職業(yè)生涯。想當年小編也是經歷了無數次的痛苦撓頭,數不清的排錯與實驗,丟掉了不知道多少根頭發(fā),最后才以”半禿之身“成就了今天的自己。所謂"不經風雨,怎能見彩虹!不見bug,怎能成神",正是如此。
今天小編就用自己十幾年的功力,來教大家如何解決我們開發(fā)路上遇到的常見bug。
遇見bug,淡定莫慌!小編告訴你,心平氣和地對待bug,去分析,去排錯!
二. NullPointerException異常
為了更好的教會大家如何解決異常,今天小編就用一個Java開發(fā)時最常見的空指針異常來進行演示,我們一起來看看NPE異常的解決過程。如下圖所示:
在這里給大家準備了一個經典的NPE空指針異常。當出現上面問題的時候,有很多小白都會不知所措,遇到問題完全沒有頭緒,抓耳撓腮的就是不知道如何下手解決。也有一些稍微表現好點的同學,會在第一時間進行百度,或者是問老師,問其他同學,最后會知道自己遇到了大名鼎鼎的空指針異常,但至于為什么出現這個異常,則又完全沒有了頭緒。小編作為一個過來人,對小白的這些表現其實是感同身受的。
今天就那么以NPE為例,帶著大家層層分析,一點點教會你如何解決異常。
三. 異常分析
1.NullPointerException
首先我們要搞清楚,自己遇到的異常到底是什么?就比如我們今天所說的空指針,到底是怎么回事呢?
java.lang.NullPointerException:空指針異常,是指我們在代碼中調用某個類對象時,結果在代碼執(zhí)行期間JVM虛擬機發(fā)現該對象沒有賦值,即值為null,此時就會出現NullPointerException異常。
2.一個案例
我們可以來看看給大家設計的下面這個案例。
2.1 測試接口
在下面的代碼中,我們會通過JDBC的方式,將數據庫表中的所有員工信息查詢并封裝到List集合中,并使用單元測試來測試接口功能。代碼如下:
2.2 查詢功能
上面的代碼執(zhí)行之后,我們會在控制臺的異常信息中發(fā)現,在第29行碼"com.qf.test.TestEmployee.testFindAllEmp(TestEmployee.java:29)"中出現了空指針問題。如果我們仔細觀察,會發(fā)現第29行代碼,又在調用第42行代碼:"com.qf.dao.impl.EmpDaoImpl.findAllEmp(EmpDaoImpl.java:42)"。我們繼續(xù)閱讀第42行代碼,如下圖所示:
該方法的邏輯是要將查詢到的多條記錄都封裝到List集合中,而List集合里添加的是員工對象,我們上面代碼的錯誤提示的就是出現在這個方法中的第42行。而42行剛好就是我們從數據庫中得到每一行每一列的字段信息。
細心的同學會看到,我們上面的Emp emp = null ; 這里只是聲明了Emp對象,但并沒new。我們每循環(huán)一次就表示會封裝一個員工信息到集合中,但卻沒有給emp對象賦值,所以此時emp對象就是null。
這樣經過層層摸排,我們就知道了產生空指針的真正原因所在,是因為我們沒有給某個對象賦值!那么該問題怎么解決呢?
四. 解決辦法
通過上面的代碼分析,我們發(fā)現出現NullPointerException異常的原因,是因為我們在接口實現類中沒有給Emp對象賦值,導致emp對象為null。當我們使用null去調用對應的方法來封裝數據時,就會出現空指針異常。其實空指針異常解決起來也比較簡單,我們只需要在第42行代碼前面加入如下操作:
上面的代碼,我們只是增加了給emp對象賦值的過程!這樣就解決了空指針異常。
五. 總結與反思
很多初學者在剛開始學習時,有時候一個變量定義錯了,或者是為了給變量賦值,都可能會引發(fā)一系列錯誤。一旦出現錯誤,很多初學者往往要花費幾十分鐘甚至幾個小時的時間去排查故障,甚至還有一些同學最后也搞不定這些錯誤,嚴重地挫傷了學習的積極性。
其實初學者遇到的絕大多數問題,都是因為粗心大意造成的。我們以后在寫代碼時,不要去求快,而是要求穩(wěn),每一行代碼都要認真思考琢磨,用心去打磨自己的項目,這正應了我們的一句老話:”磨刀不誤砍柴工“。
今天的NullPointerException異常解決過程,給了我們初學者一個警醒,寫完業(yè)務代碼后,一定要再梳理一遍業(yè)務流程,盡量要做到以下幾點:
編寫業(yè)務方法之后,根據業(yè)務需求自己再梳理一遍業(yè)務的實現過程;
如果出現了問題,可以打斷點一步步往下調試,并結合簡單的輸出語句驗證輸出結果;
只要你能夠按照小編的流程走,你會發(fā)現原來bug也沒有那么可怕?,F在你知道異常該怎么解決了嗎?