
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 - 多重捕獲塊
- 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 - 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 - 程序 API 改進
- Java - 流 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 - 巢狀 Try 塊
巢狀 Try 塊
一個 try 塊 可以巢狀在另一個 try 塊中。這種結構稱為巢狀 try 塊。每當在巢狀 try 塊中引發 異常 時,其異常會被推送到堆疊中。異常從子 try 塊傳播到父 try 塊,依此類推。
語法
巢狀 catch 塊的語法如下所示:
try { // parent try block try { // child try block } catch(ExceptionType1 e1){ // child catch block } } catch (ExceptionType2 e1) { // parent catch block }
前面的語句演示了兩個 try/catch 塊,但您可以有任意數量的塊。如果在受保護的子程式碼中發生異常,則該異常將被拋到子列表的 catch 塊中。如果丟擲的異常的資料型別與 ExceptionType1 匹配,則會在那裡捕獲它。如果不是,則異常傳遞到父 catch 語句。這將一直持續到異常被捕獲或貫穿所有 catch,在這種情況下,當前方法將停止執行,並且異常將向下拋到呼叫堆疊上的前一個方法。
使用巢狀 Try 塊時要記住的要點
子 catch 塊應該有特定的異常以提高程式碼清晰度。父 catch 塊可以處理更通用的異常,以便如果子 catch 塊無法處理異常,則父 catch 塊可以處理它。
在子 catch 塊與父 catch 塊中使用異常層次結構沒有限制。
如果異常在子 catch 塊中被正確處理,則在父 catch 塊中可以引發並處理另一個異常。
Java 巢狀 Try 塊示例
以下程式碼段顯示瞭如何使用巢狀 try/catch 語句。在此示例中,我們透過在巢狀 try 塊中將值除以 0 來建立錯誤。子 catch 塊正在處理異常並列印相同的內容。現在在父 try 塊中,我們再次透過在訪問陣列元素時使用無效的陣列索引來建立錯誤,並引發異常。
package com.tutorialspoint; public class ExcepTest { public static void main(String args[]) { try { int a[] = new int[2]; try { int b = 0; int c = 1/b; }catch(Exception e) { System.out.println("Exception thrown: " + e); } System.out.println("Access element three :" + a[3]); } catch (ArrayIndexOutOfBoundsException e) { System.out.println("Exception thrown: " + e); } System.out.println("Out of the block"); } }
輸出
Exception thrown: java.lang.ArithmeticException: / by zero Exception thrown: java.lang.ArrayIndexOutOfBoundsException: 3 Out of the block
更多示例
示例 1
在此程式碼段中,我們展示瞭如何使用巢狀 try/catch 語句的另一個示例。在此示例中,我們透過在巢狀 try 塊中將值除以 0 來建立錯誤,但我們沒有在相應的 catch 塊中進行處理。由於父 try 塊正在處理作為通用異常引發的異常,因此它捕獲了子 catch 塊引發的異常並列印相同的內容。
package com.tutorialspoint; public class ExcepTest { public static void main(String args[]) { try { int a[] = new int[2]; try { int b = 0; int c = 1/b; }catch(ArrayIndexOutOfBoundsException e) { System.out.println("Exception thrown: " + e); } System.out.println("Access element three :" + a[3]); } catch (Exception e) { System.out.println("Exception thrown: " + e); } System.out.println("Out of the block"); } }
輸出
Exception thrown: java.lang.ArithmeticException: / by zero Out of the block
示例 2
在此程式碼段中,我們展示了巢狀 try/catch 語句中沒有任何 catch 塊處理異常的情況。在此示例中,我們透過在巢狀 try 塊中將值除以 0 來建立錯誤,但我們沒有在任何 catch 塊中處理此類異常。現在 JVM 將捕獲異常並終止程式,而不會列印最後一條語句。
package com.tutorialspoint; public class ExcepTest { public static void main(String args[]) { try { int a[] = new int[2]; try { int b = 0; int c = 1/b; }catch(ArrayIndexOutOfBoundsException e) { System.out.println("Exception thrown: " + e); } System.out.println("Access element three :" + a[3]); } catch (ArrayIndexOutOfBoundsException e) { System.out.println("Exception thrown: " + e); } System.out.println("Out of the block"); } }
輸出
Exception in thread "main" java.lang.ArithmeticException: / by zero at com.tutorialspoint.ExcepTest.main(ExcepTest.java:10)