異常處理是Java軟件開發(fā)中的一個(gè)重要部分,它是關(guān)乎每個(gè)應(yīng)用的一個(gè)非功能性需求,是為了處理任何錯(cuò)誤狀況,比如資源不可訪問,非法輸入,空輸入等等,Java提供了幾個(gè)異常處理特性,以try,catch和finally關(guān)鍵字的形式內(nèi)建于語(yǔ)言自身之中,Java編程語(yǔ)言也允許你創(chuàng)建新的異常,并通過使用throw和throws關(guān)鍵字拋出它們,事實(shí)上,在Java編程中,Java的異常處理不單單是知道語(yǔ)法這么簡(jiǎn)單,它必須遵循標(biāo)準(zhǔn)的JDK庫(kù),和幾個(gè)處理錯(cuò)誤和異常的開源代碼,這里我們將討論一些關(guān)于異常處理的Java最佳實(shí)踐。
為可恢復(fù)的錯(cuò)誤使用檢查型異常,為編程錯(cuò)誤使用非檢查型錯(cuò)誤
選擇檢查型還是非檢查型異常,對(duì)于Java編程人員來說,總是讓人感到困惑。檢查型異常保證你對(duì)錯(cuò)誤條件提供異常處理代碼,這是一種從語(yǔ)言到強(qiáng)制你編寫健壯的代碼的一種方式,但同時(shí)會(huì)引入大量雜亂的代碼并導(dǎo)致其不可讀。當(dāng)然,如果你有替代品和恢復(fù)策略的話,捕捉異常并做些什么看起來似乎也在理,在Java編程中選擇檢查型異常還是運(yùn)行時(shí)異常。
在finally程序塊中關(guān)閉或者釋放資源
這在Java編程中,是一個(gè)廣為人知的最佳實(shí)踐,在處理網(wǎng)絡(luò)和IO類的時(shí)候,相當(dāng)于一個(gè)標(biāo)準(zhǔn)。在finally塊中關(guān)閉資源,在正常和異常執(zhí)行的情況下,保證之前和稀缺資源的合理釋放,這由finally塊保證。從Java7開始,該語(yǔ)言有了一項(xiàng)更有趣的功能:資源管理自動(dòng)化或者ARM塊能實(shí)現(xiàn)這一功能。盡管如此,我們?nèi)匀灰涀≡趂inally塊中關(guān)閉資源,這是對(duì)于釋放像FileDescriptors這類,應(yīng)用在socket和文件編程的情況下的有限資源很重要的。
使用標(biāo)準(zhǔn)異常
我們的第九條最佳實(shí)踐建議使用標(biāo)準(zhǔn)和內(nèi)置的Java異常。使用標(biāo)準(zhǔn)異常而不是每次創(chuàng)建我們自己的異常,對(duì)于維護(hù)性和一致性,不管是現(xiàn)在還是以后,都是最好的選擇。重用標(biāo)準(zhǔn)異常使代碼更具可讀性,因?yàn)榇蟛糠諮ava開發(fā)人員對(duì)標(biāo)準(zhǔn)的像源自于JDK的RuntimeException異常,IllegalStateException異常,IllegalArgumentException異?;蛘逳ullPointerException異常,(開發(fā)者)他們能一眼就知道每種異常的目的,而不是在代碼里查找或者在文檔里查找用戶定義的異常的目的。
記錄任何方法拋出的異常
Java編程語(yǔ)言提供了throw和throws關(guān)鍵字來拋出異常,在javadoc中用@throw記錄任何方法可能會(huì)拋出的異常。如果你編寫API或者公共接口,這就變得非常重要。任何方法拋出的異常都有相應(yīng)的文檔記錄,這樣你就能下意識(shí)的提醒任何使用(該方法)的人。
這些就是所有在Java編程中在處理異常的時(shí)候需要遵循的最佳實(shí)踐,讓我們知道了什么是在Java編程中編寫異常處理代碼時(shí)需要遵循的實(shí)踐。