Java中Finally關(guān)鍵字
final:禁止多態(tài)開(kāi)關(guān)~
修飾變量:變量不能被改變
修飾類(lèi):類(lèi)不能被繼承
修飾方法:方法不能被重寫(xiě)
finally:用在異常處理的最后一個(gè)語(yǔ)句塊
無(wú)論是否產(chǎn)生異常都要被執(zhí)行~~~
Java代碼
public final class FinallyTest { public static void main(String[] args) { try { throw new NullPointerException(); } catch (NullPointerException e) { System.out.println("程序拋出了異常"); } finally { System.out.println("執(zhí)行了finally語(yǔ)句塊"); } } }
Java中finally關(guān)鍵字的使用
與其他語(yǔ)言的模型相比,finally 關(guān)鍵字是對(duì) Java 異常處理模型的最佳補(bǔ)充。finally 結(jié)構(gòu)使代碼總會(huì)執(zhí)行,而不管有無(wú)異常發(fā)生。使用 finally 可以維護(hù)對(duì)象的內(nèi)部狀態(tài),并可以清理非內(nèi)存資源。 如果沒(méi)有 finally,您的代碼就會(huì)很費(fèi)解。例如,下面的代碼說(shuō)明,在不使用 finally 的情況下您必須如何編寫(xiě)代碼來(lái)釋放非內(nèi)存資源:
import java.net.*; import java.io.*; class WithoutFinally { public void foo() throws IOException { //在任一個(gè)空閑的端口上創(chuàng)建一個(gè)套接字 ServerSocket ss = new ServerSocket(0); try { Socket socket = ss.accept(); //此處的其他代碼... } catch (IOException e) { ss.close(); //1 throw e; } //... ss.close(); //2 } }
這段代碼創(chuàng)建了一個(gè)套接字,并調(diào)用 accept 方法。在退出該方法之前,您必須關(guān)閉此套接字,以避免資源漏洞。為了完成這一任務(wù),我們?cè)?//2 處調(diào)用 close,它是該方法的最后一條語(yǔ)句。但是,如果 try 塊中發(fā)生一個(gè)異常會(huì)怎么樣呢?在這種情況下,//2 處的 close 調(diào)用永遠(yuǎn)不會(huì)發(fā)生。因此,您必須捕獲這個(gè)異常,并在重新發(fā)出這個(gè)異常之前在 //1 處插入對(duì) close 的另一個(gè)調(diào)用。這樣就可以確保在退出該方法之前關(guān)閉套接字。
這樣編寫(xiě)代碼既麻煩又易于出錯(cuò),但在沒(méi)有 finally 的情況下這是必不可少的。不幸的是,在沒(méi)有 finally 機(jī)制的語(yǔ)言中,程序員就可能忘記以這種方式組織他們的代碼,從而導(dǎo)致資源漏洞。Java 中的 finally 子句解決了這個(gè)問(wèn)題。有了 finally,前面的代碼就可以重寫(xiě)為以下的形式:
import java.net.*; import java.io.*; class WithFinally { public void foo2() throws IOException { //在任一個(gè)空閑的端口上創(chuàng)建一個(gè)套接字 ServerSocket ss = new ServerSocket(0); try { Socket socket = ss.accept(); //此處的其他代碼... } finally { ss.close(); } } }
finally 塊確保 close 方法總被執(zhí)行,而不管 try 塊內(nèi)是否發(fā)出異常。因此,可以確保在退出該方法之前總會(huì)調(diào)用 close 方法。這樣您就可以確信套接字被關(guān)閉并且您沒(méi)有泄漏資源。在此方法中不需要再有一個(gè) catch 塊。在第一個(gè)示例中提供 catch 塊只是為了關(guān)閉套接字,現(xiàn)在這是通過(guò) finally 關(guān)閉的。如果您確實(shí)提供了一個(gè) catch 塊,則 finally 塊中的代碼在 catch 塊完成以后執(zhí)行。
finally 塊必須與 try 或 try/catch 塊配合使用。此外,不可能退出 try 塊而不執(zhí)行其 finally 塊。如果 finally 塊存在,則它總會(huì)執(zhí)行。(無(wú)論從那點(diǎn)看,這個(gè)陳述都是正確的。有一種方法可以退出 try 塊而不執(zhí)行 finally 塊。如果代碼在 try 內(nèi)部執(zhí)行一條 System.exit(0); 語(yǔ)句,則應(yīng)用程序終止而不會(huì)執(zhí)行 finally 執(zhí)行。另一方面,如果您在 try 塊執(zhí)行期間撥掉電源,finally 也不會(huì)執(zhí)行。)
相關(guān)文章
SpringSecurity?用戶帳號(hào)已被鎖定的問(wèn)題及解決方法
這篇文章主要介紹了SpringSecurity?用戶帳號(hào)已被鎖定,本文給大家分享問(wèn)題原因及解決方式,需要的朋友可以參考下2023-12-12Spring boot攔截器實(shí)現(xiàn)IP黑名單的完整步驟
這篇文章主要給大家介紹了關(guān)于Spring boot攔截器實(shí)現(xiàn)IP黑名單的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Spring boot攔截器具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06SpringBoot中的static靜態(tài)資源訪問(wèn)、參數(shù)配置、代碼自定義訪問(wèn)規(guī)則詳解
這篇文章主要介紹了SpringBoot的static靜態(tài)資源訪問(wèn)、參數(shù)配置、代碼自定義訪問(wèn)規(guī)則,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07SpringBoot集成SFTP客戶端實(shí)現(xiàn)文件上傳下載實(shí)例
這篇文章主要為大家介紹了SpringBoot集成SFTP客戶端實(shí)現(xiàn)文件上傳下載實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08Assert.assertEquals的使用方法及注意事項(xiàng)說(shuō)明
這篇文章主要介紹了Assert.assertEquals的使用方法及注意事項(xiàng)說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05Spring Data Redis對(duì)象緩存序列化問(wèn)題解決
相信在項(xiàng)目中,你一定是經(jīng)常使用Redis,在使用時(shí),有沒(méi)有遇到同我一樣,對(duì)象緩存序列化問(wèn)題的呢,本文主要介紹了Spring Data Redis對(duì)象緩存序列化問(wèn)題解決,感興趣的可以了解一下2024-01-01