詳解Java異常處理中finally子句的運用
當異常被拋出,通常方法的執(zhí)行將作一個陡峭的非線性的轉向。依賴于方法是怎樣編碼的,異常甚至可以導致方法過早返回。這在一些方法中是一個問題。例如,如果一個方法打開一個文件項并關閉,然后退出,你不希望關閉文件的代碼被異常處理機制旁路。finally關鍵字為處理這種意外而設計。
finally創(chuàng)建一個代碼塊。該代碼塊在一個try/catch 塊完成之后另一個try/catch出現(xiàn)之前執(zhí)行。finally塊無論有沒有異常拋出都會執(zhí)行。如果異常被拋出,finally甚至是在沒有與該異常相匹配的catch子句情況下也將執(zhí)行。一個方法將從一個try/catch塊返回到調用程序的任何時候,經過一個未捕獲的異?;蛘呤且粋€明確的返回語句,finally子句在方法返回之前仍將執(zhí)行。這在關閉文件句柄和釋放任何在方法開始時被分配的其他資源是很有用的。finally子句是可選項,可以有也可以無。然而每一個try語句至少需要一個catch或finally子句。
下面的例子顯示了3種不同的退出方法。每一個都執(zhí)行了finally子句:
// Demonstrate finally.
class FinallyDemo {
// Through an exception out of the method.
static void procA() {
try {
System.out.println("inside procA");
throw new RuntimeException("demo");
} finally {
System.out.println("procA's finally");
}
}
// Return from within a try block.
static void procB() {
try {
System.out.println("inside procB");
return;
} finally {
System.out.println("procB's finally");
}
}
// Execute a try block normally.
static void procC() {
try {
System.out.println("inside procC");
} finally {
System.out.println("procC's finally");
}
}
public static void main(String args[]) {
try {
procA();
} catch (Exception e) {
System.out.println("Exception caught");
}
procB();
procC();
}
}
該例中,procA( )過早地通過拋出一個異常中斷了try。Finally子句在退出時執(zhí)行。procB( )的try語句通過一個return語句退出。在procB( )返回之前finally子句執(zhí)行。在procC()中,try語句正常執(zhí)行,沒有錯誤。然而,finally塊仍將執(zhí)行。
注意:如果finally塊與一個try聯(lián)合使用,finally塊將在try結束之前執(zhí)行。
下面是上述程序產生的輸出:
inside procA procA's finally Exception caught inside procB procB's finally inside procC procC's finally
相關文章
淺談Java8 的foreach跳出循環(huán)break/return
這篇文章主要介紹了Java8 的foreach跳出循環(huán)break/return,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
深入淺出講解Spring框架中AOP及動態(tài)代理的應用
在軟件業(yè),AOP為Aspect?Oriented?Programming的縮寫,意為:面向切面編程,通過預編譯方式和運行期間動態(tài)代理實現(xiàn)程序功能的統(tǒng)一維護的一種技術2022-03-03
SpringBoot+Vue.js實現(xiàn)前后端分離的文件上傳功能
這篇文章主要介紹了SpringBoot+Vue.js實現(xiàn)前后端分離的文件上傳功能,需要的朋友可以參考下2018-06-06

