Java 多個異常共享同一個異常處理器的方法
傳統(tǒng)的異常處理
我們先來看下,傳統(tǒng)的異常處理方式:
// not share exception handler int[] intArray = new int[3]; try { for (int i = 0; i <= intArray.length; i++) { intArray[i] = i; System.out.println("intArray[" + i + "] = " + intArray[i]); System.out.println("intArray[" + i + "]模 " + (i - 2) + "的值: " + intArray[i] % (i - 2)); } } catch (ArrayIndexOutOfBoundsException e) { // ...省略了大段處理邏輯 System.out.println("異常信息:" + e); } catch (ArithmeticException e) { // ...省略了大段處理邏輯 System.out.println("異常信息:" + e); }
在上面的程序處理中,我們捕獲了可能出現(xiàn)的 ArrayIndexOutOfBoundsException 和 ArithmeticException 的異常。
共享同一個異常處理器
為了改進代碼,我們使用了 Java 7 中共享同一個異常處理器的方式,代碼改成了如下方式:
// share exception handler intArray = new int[3]; try { for (int i = 0; i <= intArray.length; i++) { intArray[i] = i; System.out.println("intArray[" + i + "] = " + intArray[i]); System.out.println("intArray[" + i + "]模 " + (i - 2) + "的值: " + intArray[i] % (i - 2)); } } catch (ArrayIndexOutOfBoundsException | ArithmeticException e) { // ...省略了大段處理邏輯 System.out.println("異常信息:" + e); } System.out.println("程序正常結(jié)束。");
在這段程序中,我們看到 ArrayIndexOutOfBoundsException 和 ArithmeticException 異常被放到了同一個異常處理器中進行了處理。這樣整體代碼看起來更加簡潔,并消除了很多的重復(fù)代碼。要知道,重復(fù)是魔鬼。
源碼
本例子的源碼,可以在 https://github.com/waylau/essential-java 中 com.waylau.essentialjava.exception
包下找到。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解spring整合shiro權(quán)限管理與數(shù)據(jù)庫設(shè)計
這篇文章主要介紹了詳解spring整合shiro權(quán)限管理與數(shù)據(jù)庫設(shè)計,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05MybatisPlus如何調(diào)用count函數(shù)
這篇文章主要介紹了MybatisPlus如何調(diào)用count函數(shù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08Spring Boot 2.4新特性減少95%內(nèi)存占用問題
這篇文章主要介紹了Spring Boot 2.4新特性減少95%內(nèi)存占用問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12idea配置全局變量Jdk、maven倉庫以及maven詳解(全文圖解)
這篇文章主要給大家介紹了關(guān)于idea配置全局變量Jdk、maven倉庫以及maven的相關(guān)資料,在配置JDK和Maven之前,需要確保已經(jīng)正確安裝了JDK和Maven,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2024-01-01詳解Spring Boot中使用@Scheduled創(chuàng)建定時任務(wù)
本篇文章中主要介紹了Spring Boot中使用@Scheduled創(chuàng)建定時任務(wù),具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-03-03解讀線程池-Executors的newSingleThreadExecutor和newFixedThreadPool(1
這篇文章主要介紹了解讀線程池-Executors的newSingleThreadExecutor和newFixedThreadPool(1)區(qū)別,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08