Java finally
當(dāng)異常被拋出,通常方法的執(zhí)行將作一個(gè)陡峭的非線性的轉(zhuǎn)向。依賴于方法是怎樣編碼的,異常甚至可以導(dǎo)致方法過早返回。這在一些方法中是一個(gè)問題。例如,如果一個(gè)方法打開一個(gè)文件項(xiàng)并關(guān)閉,然后退出,你不希望關(guān)閉文件的代碼被異常處理機(jī)制旁路。finally關(guān)鍵字為處理這種意外而設(shè)計(jì)。
finally創(chuàng)建一個(gè)代碼塊。該代碼塊在一個(gè)try/catch 塊完成之后另一個(gè)try/catch出現(xiàn)之前執(zhí)行。finally塊無論有沒有異常拋出都會執(zhí)行。如果異常被拋出,finally甚至是在沒有與該異常相匹配的catch子句情況下也將執(zhí)行。一個(gè)方法將從一個(gè)try/catch塊返回到調(diào)用程序的任何時(shí)候,經(jīng)過一個(gè)未捕獲的異常或者是一個(gè)明確的返回語句,finally子句在方法返回之前仍將執(zhí)行。這在關(guān)閉文件句柄和釋放任何在方法開始時(shí)被分配的其他資源是很有用的。finally子句是可選項(xiàng),可以有也可以無。然而每一個(gè)try語句至少需要一個(gè)catch或finally子句。
下面的例子顯示了3種不同的退出方法。每一個(gè)都執(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( )過早地通過拋出一個(gè)異常中斷了try。Finally子句在退出時(shí)執(zhí)行。procB( )的try語句通過一個(gè)return語句退出。在procB( )返回之前finally子句執(zhí)行。在procC()中,try語句正常執(zhí)行,沒有錯(cuò)誤。然而,finally塊仍將執(zhí)行。
注意:如果finally塊與一個(gè)try聯(lián)合使用,finally塊將在try結(jié)束之前執(zhí)行。
下面是上述程序產(chǎn)生的輸出:
inside procA
procA’s finally
Exception caught
inside procB
procB’s finally
inside procC
procC’s finally
七. 多線程編程
1.線程的概念
2.Java線程模型
3.主線程
4.創(chuàng)建線程
5.創(chuàng)建多線程
6.isAlive()和join()的使用
7.線程優(yōu)先級
8.線程同步
9.線程間通信
10.線程死鎖
11.線程的掛起、恢復(fù)和終止
總結(jié)
以上是生活随笔為你收集整理的Java finally的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: CSS中的层叠性、继承性、优先级、权重
- 下一篇: html中列表、表格、合并单元格