
Java 教程
- Java - 首頁
- Java - 概述
- Java - 歷史
- Java - 特性
- Java 與 C++
- JVM - Java 虛擬機器
- Java - JDK 與 JRE 與 JVM
- Java - Hello World 程式
- Java - 環境搭建
- Java - 基本語法
- Java - 變數型別
- Java - 資料型別
- Java - 型別轉換
- Java - Unicode 系統
- Java - 基本運算子
- Java - 註釋
- Java - 使用者輸入
- Java - 日期與時間
Java 控制語句
- Java - 迴圈控制
- Java - 決策制定
- Java - if-else
- Java - switch
- Java - for 迴圈
- Java - for-each 迴圈
- Java - while 迴圈
- Java - do-while 迴圈
- Java - break
- Java - continue
面向物件程式設計
- Java - OOPs 概念
- Java - 物件與類
- Java - 類屬性
- Java - 類方法
- Java - 方法
- Java - 變數作用域
- Java - 構造器
- Java - 訪問修飾符
- Java - 繼承
- Java - 聚合
- Java - 多型性
- Java - 重寫
- Java - 方法過載
- Java - 動態繫結
- Java - 靜態繫結
- Java - 例項初始化塊
- Java - 抽象
- Java - 封裝
- Java - 介面
- Java - 包
- Java - 內部類
- Java - 靜態類
- Java - 匿名類
- Java - 單例類
- Java - 包裝類
- Java - 列舉
- Java - 列舉構造器
- Java - 列舉字串
Java 內建類
Java 檔案處理
Java 錯誤與異常
- Java - 異常
- Java - try-catch 程式碼塊
- Java - try-with-resources
- Java - 多重 catch 程式碼塊
- Java - 巢狀 try 程式碼塊
- Java - finally 程式碼塊
- Java - throw 異常
- Java - 異常傳播
- Java - 內建異常
- Java - 自定義異常
Java 多執行緒
- Java - 多執行緒
- Java - 執行緒生命週期
- Java - 建立執行緒
- Java - 啟動執行緒
- Java - 合併執行緒
- Java - 執行緒命名
- Java - 執行緒排程器
- Java - 執行緒池
- Java - 主執行緒
- Java - 執行緒優先順序
- Java - 守護執行緒
- Java - 執行緒組
- Java - 關閉鉤子
Java 同步
- Java - 同步
- Java - 程式碼塊同步
- Java - 靜態同步
- Java - 執行緒間通訊
- Java - 執行緒死鎖
- Java - 中斷執行緒
- Java - 執行緒控制
- Java - 可重入監視器
Java 網路程式設計
- Java - 網路程式設計
- Java - Socket 程式設計
- Java - URL 處理
- Java - URL 類
- Java - URLConnection 類
- Java - HttpURLConnection 類
- Java - Socket 類
- Java - 泛型
Java 集合
Java 介面
Java 資料結構
Java 集合演算法
高階 Java
- Java - 命令列引數
- Java - Lambda 表示式
- Java - 傳送郵件
- Java - Applet 基礎
- Java - Javadoc 註釋
- Java - 自動裝箱和拆箱
- Java - 檔案不匹配方法
- Java - REPL (JShell)
- Java - 多版本 Jar 檔案
- Java - 私有介面方法
- Java - 內部類菱形運算子
- Java - 多解析度影像 API
- Java - 集合工廠方法
- Java - 模組系統
- Java - Nashorn JavaScript
- Java - Optional 類
- Java - 方法引用
- Java - 函式式介面
- Java - 預設方法
- Java - Base64 編碼解碼
- Java - switch 表示式
- Java - Teeing 收集器
- Java - 微基準測試
- Java - 文字塊
- Java - 動態 CDS 歸檔
- Java - Z 垃圾收集器 (ZGC)
- Java - 空指標異常
- Java - 打包工具
- Java - 密封類
- Java - 記錄類
- Java - 隱藏類
- Java - 模式匹配
- Java - 簡潔數字格式化
- Java - 垃圾收集
- Java - JIT 編譯器
Java 雜項
- Java - 遞迴
- Java - 正則表示式
- Java - 序列化
- Java - 字串
- Java - Process API 改進
- Java - Stream API 改進
- Java - 增強 @Deprecated 註解
- Java - CompletableFuture API 改進
- Java - 流
- Java - 日期時間 API
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java API 與框架
Java 類引用
- Java - Scanner
- Java - 陣列
- Java - 字串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用資源
Java - finally 程式碼塊
Java 中的 finally 程式碼塊
finally 程式碼塊位於 try 程式碼塊或 catch 程式碼塊之後。無論是否發生異常,finally 程式碼塊中的程式碼始終都會執行。
使用 finally 程式碼塊,您可以執行任何您想要執行的清理型別語句,無論受保護的程式碼中發生了什麼。
語法:finally 程式碼塊
finally 程式碼塊出現在 catch 程式碼塊的末尾,並具有以下語法:
try { // Protected code } catch (ExceptionType1 e1) { // Catch block } catch (ExceptionType2 e2) { // Catch block } catch (ExceptionType3 e3) { // Catch block }finally { // The finally block always executes. }
使用 finally 程式碼塊時需要注意的事項
catch 子句不能沒有 try 語句。
並非每次 try/catch 程式碼塊都必須有 finally 子句。
try 程式碼塊不能沒有 catch 子句或 finally 子句。
try、catch、finally 程式碼塊之間不能有任何程式碼。
如果在 finally 程式碼塊之前呼叫了 exit() 方法或程式執行中發生了致命錯誤,則不會執行 finally 程式碼塊。
即使方法在 finally 程式碼塊之前返回了一個值,finally 程式碼塊也會執行。
為什麼要使用 Java finally 程式碼塊?
- Java finally 程式碼塊可用於清理(關閉)連線、開啟的檔案、流等,這些必須在程式退出之前關閉。
- 它還可以用於列印一些最終資訊。
Java finally 程式碼塊示例
以下程式碼段演示瞭如何在處理異常後使用 try/catch 語句後的 finally 程式碼塊。在這個例子中,我們建立了一個錯誤,使用無效索引訪問陣列的元素。catch 程式碼塊處理異常並列印它。現在,在 finally 程式碼塊中,我們列印一個語句,表示 finally 程式碼塊正在執行。
package com.tutorialspoint; public class ExcepTest { public static void main(String args[]) { int a[] = new int[2]; try { System.out.println("Access element three :" + a[3]); } catch (ArrayIndexOutOfBoundsException e) { System.out.println("Exception thrown :" + e); }finally { a[0] = 6; System.out.println("First element value: " + a[0]); System.out.println("The finally statement is executed"); } } }
輸出
Exception thrown :java.lang.ArrayIndexOutOfBoundsException: 3 First element value: 6 The finally statement is executed
更多示例
示例 1
以下程式碼段演示瞭如何在即使沒有處理異常的情況下,在 try/catch 語句之後使用 finally 程式碼塊。在這個例子中,我們建立了一個錯誤,使用無效索引訪問陣列的元素。由於 catch 程式碼塊沒有處理異常,我們可以在輸出中檢查 finally 程式碼塊是否列印了一個語句,表示 finally 程式碼塊正在執行。
package com.tutorialspoint; public class ExcepTest { public static void main(String args[]) { int a[] = new int[2]; try { System.out.println("Access element three :" + a[3]); } catch (ArithmeticException e) { System.out.println("Exception thrown :" + e); }finally { a[0] = 6; System.out.println("First element value: " + a[0]); System.out.println("The finally statement is executed"); } } }
輸出
First element value: 6 The finally statement is executed Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 3 at com.tutorialspoint.ExcepTest.main(ExcepTest.java:8)
示例 2
以下程式碼段演示瞭如何在 try 程式碼塊中方法可以返回值的情況下使用 finally 程式碼塊。在這個例子中,我們在 try 程式碼塊中返回一個值。我們可以在輸出中檢查 finally 程式碼塊是否列印了一個語句,表示即使方法向呼叫函式返回了一個值後,finally 程式碼塊也正在執行。
package com.tutorialspoint; public class ExcepTest { public static void main(String args[]) { System.out.println(testFinallyBlock()); } private static int testFinallyBlock() { int a[] = new int[2]; try { return 1; } catch (ArrayIndexOutOfBoundsException e) { System.out.println("Exception thrown :" + e); }finally { a[0] = 6; System.out.println("First element value: " + a[0]); System.out.println("The finally statement is executed"); } return 0; } }
輸出
First element value: 6 The finally statement is executed 1