幾種常見的Java運(yùn)行時(shí)異常小結(jié)
前言
在Java編程中,異常處理是一個(gè)至關(guān)重要的部分。它允許我們在程序運(yùn)行時(shí)檢測和處理錯(cuò)誤條件,以確保程序的穩(wěn)定性和可靠性。在Java中,異常被分為兩大類:檢查異常(checked exceptions)和運(yùn)行時(shí)異常(runtime exceptions)。運(yùn)行時(shí)異常是那些不需要在代碼中顯式捕獲的異常,它們通常在運(yùn)行時(shí)由JVM自動(dòng)拋出。
以下是幾種常見的Java運(yùn)行時(shí)異常:
1、ArithmeticException(算術(shù)異常)
ArithmeticException是當(dāng)算術(shù)運(yùn)算發(fā)生錯(cuò)誤時(shí)拋出的異常,比如除以零。
int a = 10; int b = 0; int c = a / b; // 這會(huì)拋出ArithmeticException,因?yàn)槌龜?shù)不能為零
2、ClassCastException (類轉(zhuǎn)換異常)
ClassCastException是當(dāng)試圖將對象強(qiáng)制轉(zhuǎn)換為不兼容的類時(shí)拋出的異常。
Object obj = "Hello"; Integer i = (Integer) obj; // 這會(huì)拋出ClassCastException,因?yàn)閛bj不是Integer類型
3、IllegalArgumentException (非法參數(shù)異常)
IllegalArgumentException是當(dāng)向方法傳遞不合法或不適當(dāng)?shù)膮?shù)時(shí)拋出的異常。雖然這不是一個(gè)標(biāo)準(zhǔn)的運(yùn)行時(shí)異常(它實(shí)際上是一個(gè)檢查異常的超類RuntimeException的子類),但它通常在運(yùn)行時(shí)被拋出,因此也經(jīng)常被歸類為運(yùn)行時(shí)異常。
public void printNumber(int number) { if (number < 0) { throw new IllegalArgumentException("Number cannot be negative"); } System.out.println(number); }
4、IndexOutOfBoundsException (下標(biāo)越界異常)
IndexOutOfBoundsException是當(dāng)訪問數(shù)組、字符串或集合的非法索引時(shí)拋出的異常。
int[] array = new int[5]; int element = array[10]; // 這會(huì)拋出IndexOutOfBoundsException,因?yàn)樗饕?0超出了數(shù)組范圍
5、NullPointerException (空指針異常)
NullPointerException是當(dāng)應(yīng)用程序試圖在需要對象的地方使用null時(shí)拋出的異常。這是Java中最常見的運(yùn)行時(shí)異常之一。
String str = null; int length = str.length(); // 這會(huì)拋出NullPointerException,因?yàn)閟tr是null
6、SecurityException (安全異常)
SecurityException是當(dāng)安全管理器不允許執(zhí)行請求的安全敏感操作時(shí)拋出的異常。這通常發(fā)生在訪問系統(tǒng)資源或執(zhí)行受限制的操作時(shí)。
// 假設(shè)有一個(gè)安全管理器設(shè)置了特定的安全策略 // 試圖執(zhí)行受限制的操作可能會(huì)拋出SecurityException
附:在Java中捕獲和處理異常通常使用try-catch塊
當(dāng)你預(yù)計(jì)某段代碼可能會(huì)拋出異常時(shí),你可以將這段代碼放在try塊中,并在catch塊中處理這個(gè)異常。以下是一個(gè)簡單的示例,展示了如何捕獲和處理異常:
public class ExceptionHandlingExample { public static void main(String[] args) { try { // 可能會(huì)拋出異常的代碼 int result = 10 / 0; // 這會(huì)拋出ArithmeticException } catch (ArithmeticException e) { // 處理ArithmeticException異常的代碼 System.out.println("捕獲到算術(shù)異常: " + e.getMessage()); } catch (Exception e) { // 處理其他類型異常的代碼(可選) // 注意:通常不建議捕獲所有異常(Exception),除非你確實(shí)打算處理所有類型的異常 System.out.println("捕獲到異常: " + e.getMessage()); e.printStackTrace(); // 打印異常的堆棧跟蹤信息 } finally { // 無論是否發(fā)生異常都會(huì)執(zhí)行的代碼(可選) System.out.println("finally塊中的代碼,無論是否發(fā)生異常都會(huì)執(zhí)行"); } } } 在這個(gè)示例中,我們嘗試執(zhí)行一個(gè)會(huì)導(dǎo)致ArithmeticException的除法操作(除以0)。這個(gè)操作被放在try塊中,因此如果發(fā)生異常,控制流將轉(zhuǎn)移到相應(yīng)的catch塊。在這個(gè)例子中,我們有一個(gè)專門捕獲ArithmeticException的catch塊,它會(huì)打印出一條錯(cuò)誤消息。
如果try塊中的代碼拋出了其他類型的異常(在這個(gè)示例中沒有),并且沒有相應(yīng)的catch塊來捕獲它,那么異常將會(huì)繼續(xù)向上傳播,直到找到一個(gè)能夠處理它的catch塊,或者如果沒有找到,那么程序?qū)?huì)終止并打印出異常的堆棧跟蹤信息。
finally塊是可選的,它包含的代碼無論是否發(fā)生異常都會(huì)執(zhí)行。這通常用于執(zhí)行清理操作,如關(guān)閉文件或網(wǎng)絡(luò)連接。注意,如果在try或catch塊中使用了return、break或continue語句,那么finally塊仍然會(huì)執(zhí)行,但finally塊之后的代碼(如果有的話)可能不會(huì)執(zhí)行。
總結(jié)
到此這篇關(guān)于幾種常見的Java運(yùn)行時(shí)異常的文章就介紹到這了,更多相關(guān)Java運(yùn)行異常小結(jié)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mybatis代碼生成+自定義注解+自定義注釋實(shí)例
這篇文章主要介紹了mybatis代碼生成+自定義注解+自定義注釋實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10SpringBoot如何使用@Value取配置文件中的map配置
這篇文章主要介紹了SpringBoot如何使用@Value取配置文件中的map配置方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05MyBatis-Plus自動(dòng)化填充的踩坑記錄及解決
這篇文章主要介紹了MyBatis-Plus自動(dòng)化填充的踩坑記錄及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Java中l(wèi)ogback?自動(dòng)刷新不生效的問題解決
本文主要介紹了Java中l(wèi)ogback?自動(dòng)刷新不生效的問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05java實(shí)現(xiàn)/創(chuàng)建線程的幾種方式小結(jié)
在JAVA中,用Thread類代表線程,所有線程對象都必須是Thread類或者Thread類子類的實(shí)例,下面這篇文章主要介紹了java實(shí)現(xiàn)/創(chuàng)建線程的幾種方式,需要的朋友可以參考下2021-08-08