通常在面試中,只要是疑問句一般答案都是“否定”的,因?yàn)槿绻恰按_定”和“正?!钡?,那面試官就沒有必要再問了嘛,而今天這道題的答案也是符合這個(gè)套路。
正常運(yùn)行的情況下,finally 中的代碼是一定會(huì)執(zhí)行的,但是,如果遇到以下異常情況,那么 finally 中的代碼就不會(huì)繼續(xù)執(zhí)行了:
程序在 try 塊中遇到 System.exit() 方法,會(huì)立即終止程序的執(zhí)行,這時(shí) finally 塊中的代碼不會(huì)被執(zhí)行,例如以下代碼:
public class FinallyExample { public static void main(String[] args) { try { System.out.println("執(zhí)行 try 代碼."); System.exit(0); } finally { System.out.println("執(zhí)行 finally 代碼."); } }}
以上程序的執(zhí)行結(jié)果如下:
在 try 快中遇到 Runtime.getRuntime().halt() 代碼,強(qiáng)制終止正在運(yùn)行的 JVM。與 System.exit()方法不同,此方法不會(huì)觸發(fā) JVM 關(guān)閉序列。因此,當(dāng)我們調(diào)用 halt 方法時(shí),都不會(huì)執(zhí)行關(guān)閉鉤子或終結(jié)器。實(shí)現(xiàn)代碼如下:
public class FinallyExample { public static void main(String[] args) { try { System.out.println("執(zhí)行 try 代碼."); Runtime.getRuntime().halt(0); } finally { System.out.println("執(zhí)行 finally 代碼."); } }}
以上程序的執(zhí)行結(jié)果如下:
程序在 try 塊中遇到無(wú)限循環(huán)或者發(fā)生死鎖等情況時(shí),程序可能無(wú)法正常跳出 try 塊,此時(shí) finally 塊中的代碼也不會(huì)被執(zhí)行。
掉電問題,程序還沒有執(zhí)行到 finally 就掉電了(停電了),那 finally 中的代碼自然也不會(huì)執(zhí)行。
JVM 異常崩潰問題導(dǎo)致程序不能繼續(xù)執(zhí)行,那么 finally 的代碼也不會(huì)執(zhí)行。
在編程中,鉤子方法(Hook Method)是一種由父類提供的空或默認(rèn)實(shí)現(xiàn)的方法,子類可以選擇性地重寫或擴(kuò)展該方法,以實(shí)現(xiàn)特定的行為或定制化邏輯。鉤子方法可以在父類中被調(diào)用,以提供一種可插拔的方式來(lái)影響父類的行為。鉤子方法通常用于框架或模板方法設(shè)計(jì)模式中??蚣芴峁┮粋€(gè)骨架或模板,其中包含一些已經(jīng)實(shí)現(xiàn)的方法及預(yù)留的鉤子方法。具體的子類可以通過(guò)重寫鉤子方法來(lái)插入定制邏輯,從而影響父類方法的實(shí)現(xiàn)方式。
正常運(yùn)行的情況下,finally 中的代碼是一定會(huì)執(zhí)行的,但是,如果遇到 System.exit() 方法或 Runtime.getRuntime().halt() 方法,或者是 try 中發(fā)生了死循環(huán)、死鎖,遇到了掉電、JVM 崩潰等問題,那么 finally 中的代碼也是不會(huì)執(zhí)行的。
System.exit() 和 Runtime.getRuntime().halt() 都可以用于終止 Java 程序的執(zhí)行,但它們之間有以下區(qū)別:
例如以下代碼,使用 exit() 方法會(huì)執(zhí)行 JVM 關(guān)閉鉤子:
class ExitDemo { // 注冊(cè)退出鉤子程序 static { Runtime.getRuntime().addShutdownHook(new Thread(() -> { System.out.println("執(zhí)行 ShutdownHook 方法"); })); } public static void main(String[] args) { try { System.out.println("執(zhí)行 try 代碼。"); // 使用 System.exit() 退出程序 System.exit(0); } finally { System.out.println("執(zhí)行 finally 代碼。"); } }}
以上程序的執(zhí)行結(jié)果如下:
而 halt() 退出的方法,并不會(huì)執(zhí)行 JVM 關(guān)閉鉤子,示例代碼如下:
class ExitDemo { // 注冊(cè)退出鉤子程序 static { Runtime.getRuntime().addShutdownHook(new Thread(() -> { System.out.println("執(zhí)行 ShutdownHook 方法"); })); } public static void main(String[] args) { try { System.out.println("執(zhí)行 try 代碼。"); // 使用 Runtime.getRuntime().halt() 退出程序 Runtime.getRuntime().halt(0); } finally { System.out.println("執(zhí)行 finally 代碼。"); } }}
以上程序的執(zhí)行結(jié)果如下:
正常運(yùn)行的情況下,finally 中的代碼是一定會(huì)執(zhí)行的,但是,如果遇到 System.exit() 方法或 Runtime.getRuntime().halt() 方法,或者是 try 中發(fā)生了死循環(huán)、死鎖,遇到了掉電、JVM 崩潰等問題,finally 中的代碼是不會(huì)執(zhí)行的。而 exit() 方法會(huì)執(zhí)行 JVM 關(guān)閉鉤子方法或終結(jié)器,但 halt() 方法并不會(huì)執(zhí)行鉤子方法或終結(jié)器。
本文鏈接:http://www.tebozhan.com/showinfo-26-48738-0.htmlFinally中的代碼一定會(huì)執(zhí)行嗎?
聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com