您好,登錄后才能下訂單哦!
JAVA中異常處理使用不當該怎么辦,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
犯這種錯誤的人比較少,一般發生在剛學會 Java 或者剛參加工作不久的人身上。
所謂“空 catch 語句塊”就是在 catch 語句塊中沒有對異常作任何處理(比如記錯誤日志),導致異常信息被丟棄/忽略。一旦程序不能正確運行,由于查不到任何 log 信息,只好從頭看代碼,靠肉眼找 bug。
很多人在 catch 語句之后不使用 finally 語句。由于在 try 語句中可能會涉及資源的申請和釋放。如果在資源申請之后、資源釋放之前拋出異常,就會發生資源泄露。
有些人為了省事,只在自己模塊的最外層代碼包一個 try 語句塊,然后 catch(Exception)。不管捕獲到什么異常,都作統一 log 了事。這種做法比“空 catch 語句塊”稍好,但由于不能對具體的異常進行具體處理,對一些可恢復的異常(下面會提到),喪失了恢復的機會。而且也可能導致上述提到的資源泄露的問題。
有些人放著 Java 的異常機制不用,而用函數返回值來表示成功/失敗(比如:返回 true 表示成功、false 表示失敗),簡直是“捧著金碗要飯”。個人感覺,從 C 轉到 Java 的人比較容易有此毛病。這種做法會導致如下幾個問題:
1. 返回值一般用整數值或布爾值表示,傳遞的信息過于簡陋;
2. 一旦調用者忽略了錯誤返回碼,就會導致和“空 catch 語句塊”類似的問題;
2. 對同一個函數的多處調用,都需要對返回值進行重復判斷,導致代碼冗余。
這個現象比較普遍,俺發現很多2年以上 Java 工作經驗的人尚未完全搞明白兩者的區別。看來這個問題得詳細說一下。
當初Java的設計者有意區分這兩種異常,是別有深意的。其中“Checked Exception”用于表示可恢復的異常(也就是你必須檢查的異常);而“Runtime Exception”表示不可恢復的異常(也就是運行時異常,主要是程序 bug 和致命錯誤,你【不需要】檢查)。不過這種做法引來了很多爭議(包括很多 Java 大牛),鑒于本帖子主要針對新手,以后再專門來聊這個爭議的話題。
為了便于理解,下面我舉一個例子來說明。假設你要寫一個 Download 函數,根據傳入的 URL(String 參數)返回對應網頁的內容文本。這時候有兩種情況你需要處理:
1. 如果傳入的 URL 參數是 null,這表明該函數的調用者出 bug 了,而程序本身的 bug 是很難在運行時自我恢復的。這時候 Download 函數必須拋出 Runtime Exception。并且 Download 函數的調用者【不應該】嘗試去處理這個異常,必須讓它【盡早】暴露出來(比如讓 JVM 自己終止運行)。
2. 如果傳入的 URL 參數非 null,但是它包含的字符串不是一個合法的URL格式(可能由于用戶輸入錯誤導致)。這時候 Download 函數必須拋出 Checked Exception。并且 Download 函數的調用者必須捕獲該異常并進行相應的處理(比如提示用戶重新輸入 URL)。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。