蘇州培訓(xùn)網(wǎng) > 蘇州JAVA培訓(xùn)機(jī)構(gòu) > 三網(wǎng)IT
首頁(yè) 培訓(xùn)網(wǎng) 最新資訊 熱門(mén)問(wèn)答

三網(wǎng)IT

免費(fèi)試聽(tīng) 13013833891

您當(dāng)前的位置: 資訊首頁(yè) > JAVA培訓(xùn)資訊 > 蘇州JAVA高級(jí)培訓(xùn)

蘇州JAVA高級(jí)培訓(xùn)

來(lái)源:教育聯(lián)展網(wǎng)    編輯:佚名    發(fā)布時(shí)間:2018-04-08

蘇州JAVA高級(jí)培訓(xùn)

在 Java 中,異常處理是個(gè)很麻煩的事情。初學(xué)者覺(jué)得它很難理解,甚至是經(jīng)驗(yàn)豐富的開(kāi)發(fā)者也要花費(fèi)很長(zhǎng)時(shí)間決定異常是要處理掉和拋出。

所以很多開(kāi)發(fā)團(tuán)隊(duì)約定一些原則處理異常。如果你是一個(gè)團(tuán)隊(duì)的新成員,你可能會(huì)很驚訝,因?yàn)樗麄兗s定的規(guī)則可能和你以前使用的規(guī)則不一樣。

不過(guò),有很多**實(shí)踐的規(guī)則,被大部分團(tuán)隊(duì)接受。這里有 9 大重要的約定,幫助你學(xué)習(xí)或者改進(jìn)異常處理。

1
在 Finally 清理資源或者使用 Try-With-Resource 特性

大部分情況下,在 try 代碼塊中使用資源后需要關(guān)閉資源,例如 InputStream 。在這些情況下,一種常見(jiàn)的失誤就是在 try 代碼塊的**后關(guān)閉資源。

蘇州JAVA高級(jí)培訓(xùn)

問(wèn)題就是,只有沒(méi)有異常拋出的時(shí)候,這段代碼才可以正常工作。try 代碼塊內(nèi)代碼會(huì)正常執(zhí)行,并且資源可以正常關(guān)閉。但是,使用 try 代碼塊是有原因的,一般調(diào)用一個(gè)或多個(gè)可能拋出異常的方法,而且,你自己也可能會(huì)拋出一個(gè)異常,這意味著代碼可能不會(huì)執(zhí)行到 try 代碼塊的**后部分。結(jié)果就是,你并沒(méi)有關(guān)閉資源。

所以,你應(yīng)該把清理工作的代碼放到 finally 里去,或者使用 try-with-resource 特性。

使用 Finally 代碼塊

與前面幾行 try 代碼塊不同,finally 代碼塊總是會(huì)被執(zhí)行。不管 try 代碼塊成功執(zhí)行之后還是你在 catch 代碼塊中處理完異常后都會(huì)執(zhí)行。因此,你可以確保你清理了所有打開(kāi)的資源。

蘇州JAVA高級(jí)培訓(xùn)班

Java 7 的 Try-With-Resource 語(yǔ)法

另一個(gè)可選的方案是 try-with-resource 語(yǔ)法,我在介紹 Java 的異常處理里更詳細(xì)的介紹了它。

如果你的資源實(shí)現(xiàn)了 AutoCloseable 接口,你可以使用這個(gè)語(yǔ)法。大多數(shù)的 Java 標(biāo)準(zhǔn)資源都繼承了這個(gè)接口。當(dāng)你在 try 子句中打開(kāi)資源,資源會(huì)在 try 代碼塊執(zhí)行后或異常處理后自動(dòng)關(guān)閉。

蘇州JAVA高級(jí)培訓(xùn)哪家好

2
優(yōu)先明確異常

你拋出的異常越明確越好,永遠(yuǎn)記住,你的同事或者幾個(gè)月之后的你,將會(huì)調(diào)用你的方法并且處理異常。

因此需要保證提供給他們盡可能多的信息。這樣你的 API 更容易被理解。你的方法的調(diào)用者能夠更好的處理異常并且避免額外的檢查。

因此,總是嘗試尋找**適合你的異常事件的類(lèi),例如,拋出一個(gè) NumberFormatException 來(lái)替換一個(gè) IllegalArgumentException 。避免拋出一個(gè)不明確的異常。

3
記錄指定的異常

每當(dāng)你在方法簽名中指定異常,你也應(yīng)該在 Javadoc 中記錄它。 這與上一個(gè)**實(shí)踐具有相同的目標(biāo):盡可能多地向調(diào)用者提供信息,以便避免或處理異常。

因此,請(qǐng)確保向 Javadoc 添加 @throws 聲明并描述可能導(dǎo)致異常的情況。

4
使用描述性消息拋出異常

這個(gè)**實(shí)踐背后的想法與前兩個(gè)類(lèi)似。但這一次,你不會(huì)將信息提供給方法的調(diào)用者。每個(gè)必須了解在日志文件或監(jiān)視工具中報(bào)告異常情況時(shí)發(fā)生了什么情況的人都可以讀取異常消息。

因此,應(yīng)該盡可能精確地描述問(wèn)題,并提供**相關(guān)的信息來(lái)了解異常事件。

不要誤會(huì)我的意思,你不用去寫(xiě)一段文字。但你也應(yīng)該在1-2個(gè)短句中解釋異常的原因。這有助于你的運(yùn)營(yíng)團(tuán)隊(duì)了解問(wèn)題的嚴(yán)重性,并且還可以讓你更**地分析任何服務(wù)突發(fā)事件。

如果拋出一個(gè)特定的異常,它的類(lèi)名很可能已經(jīng)描述了這種錯(cuò)誤。所以,你不需要提供很多額外的信息。一個(gè)很好的例子是 NumberFormatException 。當(dāng)你以錯(cuò)誤的格式提供 String 時(shí),它將被 java.lang.Long 類(lèi)的構(gòu)造函數(shù)拋出。

NumberFormatException 類(lèi)的名稱(chēng)已經(jīng)告訴你這種問(wèn)題。它的消息表示只需要提供導(dǎo)致問(wèn)題的輸入字符串。如果異常類(lèi)的名稱(chēng)不具有表達(dá)性,則需要在消息中提供所需的信息。

17:17:26,386 ERROR TestExceptionHandling:52 - java.lang.NumberFormatException: For input string: "xyz"

5
優(yōu)先捕獲**具體的異常

大多數(shù) IDE 都可以幫助你實(shí)現(xiàn)這個(gè)**實(shí)踐。當(dāng)你嘗試首先捕獲較不具體的異常時(shí),它們會(huì)報(bào)告無(wú)法訪問(wèn)的代碼塊。

但問(wèn)題在于,只有匹配異常的**個(gè) catch 塊會(huì)被執(zhí)行。 因此,如果首先捕獲 IllegalArgumentException ,則永遠(yuǎn)不會(huì)到達(dá)應(yīng)該處理更具體的 NumberFormatException 的 catch 塊,因?yàn)樗?IllegalArgumentException 的子類(lèi)。

總是優(yōu)先捕獲**具體的異常類(lèi),并將不太具體的 catch 塊添加到列表的末尾。

你可以在下面的代碼片斷中看到這樣一個(gè) try-catch 語(yǔ)句的例子。 **個(gè) catch 塊處理所有 NumberFormatException 異常,第二個(gè)處理所有非 NumberFormatException 異常的  IllegalArgumentException 異常。

6
不要捕獲 Throwable 類(lèi)

Throwable 是所有異常和錯(cuò)誤的超類(lèi)。你可以在 catch 子句中使用它,但是你永遠(yuǎn)不應(yīng)該這樣做!

如果在 catch 子句中使用 Throwable ,它不僅會(huì)捕獲所有異常,也將捕獲所有的錯(cuò)誤。JVM 拋出錯(cuò)誤,指出不應(yīng)該由應(yīng)用程序處理的嚴(yán)重問(wèn)題。 典型的例子是 OutOfMemoryError 或者 StackOverflowError 。 兩者都是由應(yīng)用程序控制之外的情況引起的,無(wú)法處理。

所以,**不要捕獲 Throwable ,除非你確定自己處于一種特殊的情況下能夠處理錯(cuò)誤。

7
不要忽略異常

你曾經(jīng)有去分析過(guò)一個(gè)只執(zhí)行了你用例的**部分的 bug 報(bào)告嗎?

這通常是由于一個(gè)被忽略的異常造成的。開(kāi)發(fā)者可能會(huì)非??隙?,它永遠(yuǎn)不會(huì)被拋出,并添加一個(gè) catch 塊,不做處理或不記錄它。而當(dāng)你發(fā)現(xiàn)這個(gè)塊時(shí),你很可能甚至?xí)l(fā)現(xiàn)其中有一個(gè)“這永遠(yuǎn)不會(huì)發(fā)生”的注釋。

蘇州JAVA高級(jí)培訓(xùn)哪個(gè)好

那么,你可能正在分析一個(gè)不可能發(fā)生的問(wèn)題。

所以,請(qǐng)不要忽略任何一個(gè)異常。 你不知道代碼將來(lái)如何改變。有人可能會(huì)在沒(méi)有意識(shí)到會(huì)造成問(wèn)題的情況下,刪除阻止異常事件的驗(yàn)證。或者是拋出異常的代碼被改變,現(xiàn)在拋出同一個(gè)類(lèi)的多個(gè)異常,而調(diào)用的代碼并不能阻止所有異常。

你至少應(yīng)該寫(xiě)一條日志信息,告訴大家這個(gè)不可思議的事發(fā)生了,而且有人需要檢查它。

蘇州JAVA高級(jí)培訓(xùn)哪里好

8
不要記錄日志和拋出錯(cuò)誤

這可能是該文章中**常被忽略的**實(shí)踐。 你可以找到很多的其中有一個(gè)異常被捕獲的代碼片段,甚至是一些代碼庫(kù),被記錄和重新拋出。

蘇州JAVA高級(jí)培訓(xùn)好么

在發(fā)生異常時(shí)記錄異常可能會(huì)感覺(jué)很直觀,然后重新拋出異常,以便調(diào)用者可以適當(dāng)?shù)靥幚懋惓?。但它?huì)為同一個(gè)異常重復(fù)寫(xiě)入多個(gè)錯(cuò)誤消息。

蘇州JAVA高級(jí)培訓(xùn)學(xué)校

附加消息也不會(huì)添加任何信息。正如在**實(shí)踐#4中所解釋的那樣,異常消息應(yīng)該描述異常事件。 堆棧跟蹤告訴你在哪個(gè)類(lèi),方法和行中拋出異常。

如果你需要添加其他信息,則應(yīng)該捕獲異常并將其包裝在自定義的信息中。 但請(qǐng)務(wù)必遵循**實(shí)踐9。

蘇州JAVA高級(jí)培訓(xùn)機(jī)構(gòu)

所以,只捕獲你想處理的異常。 否則,在方法簽名中指定它,并讓調(diào)用者處理它。

9
封裝好的異常類(lèi)而不使用

有時(shí)候,**是捕獲一個(gè)標(biāo)準(zhǔn)異常并將其封裝成一定制的異常。一個(gè)典型的例子是應(yīng)用程序或框架特定的業(yè)務(wù)異常。允許你添加些額外的信息,并且你也可以為你的異常類(lèi)實(shí)現(xiàn)一個(gè)特殊的處理。

在你這樣做時(shí),請(qǐng)確保將原始異常設(shè)置為原因(注:參考下方代碼 NumberFormatException e 中的原始異常 e )。Exception 類(lèi)提供了特殊的構(gòu)造函數(shù)方法,它接受一個(gè) Throwable 作為參數(shù)。

另外,你將會(huì)丟失堆棧跟蹤和原始異常的消息,這將會(huì)使分析導(dǎo)致異常的異常事件變得困難。

蘇州JAVA高級(jí)培訓(xùn)中心

10
總結(jié)

如你所見(jiàn),當(dāng)你拋出或捕獲異常的時(shí)候,有很多不同的事情需要考慮,而且大部分事情都是為了改善代碼的可讀性或者 API 的可用性。

異常通常都是一種異常處理技巧,同時(shí)也是一種通信媒介。因此,為了和同事更好的合作,一個(gè)團(tuán)隊(duì)必須要制定出一個(gè)**實(shí)踐和規(guī)則,只有這樣團(tuán)隊(duì)成員才能理解這些通用概念,同時(shí)在工作中使用它。



咨詢(xún)聯(lián)系方式:13861302024(楊老師)或者QQ:2589245390 還可以直接在線咨詢(xún)

更多JAVA課程推薦:

蘇州JAVA培訓(xùn)網(wǎng)

蘇州JAVA軟件培訓(xùn)

蘇州三網(wǎng)IT教育培訓(xùn)

蘇州其然軟件開(kāi)發(fā)培訓(xùn)

上一篇:蘇州JAVA中?級(jí)培訓(xùn) 下一篇:蘇州初學(xué)者JAVA工?程師培訓(xùn)
蘇州JAVA

免費(fèi)體驗(yàn)課開(kāi)班倒計(jì)時(shí)

11: 41: 09

稍后會(huì)有專(zhuān)業(yè)老師給您回電,請(qǐng)保持電話暢通

咨詢(xún)電話:13013833891

校區(qū)導(dǎo)航

1個(gè)校區(qū)

蘇州三網(wǎng)IT教育
推薦機(jī)構(gòu) 全國(guó)分站 更多課程

今日已有25人申請(qǐng),本月限額500

申請(qǐng)?jiān)嚶?tīng)名額

已有10254人申請(qǐng)免費(fèi)試聽(tīng)

01電話咨詢(xún) | 13013833891

QQ:1413838287
加盟合作:0755-83654572