自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Java拋出異常后,后續(xù)代碼是否繼續(xù)執(zhí)行?

開發(fā) 后端
Java 拋出異常后,后面的語句到底是怎么執(zhí)行的呢?哪些會(huì)繼續(xù)執(zhí)行,哪些不再執(zhí)行,這是本章要探討的問題。

Java 拋出異常后,后面的語句到底是怎么執(zhí)行的呢?哪些會(huì)繼續(xù)執(zhí)行,哪些不再執(zhí)行,這是本章要探討的問題。為方便廣大友友解決問題,先把結(jié)論丟出來:

  • 有 try-catch 語句塊,并且 throw 在 catch 語句塊里,那么 try 語句塊中引發(fā)異常(報(bào)錯(cuò))的那一行代碼的后續(xù)代碼都不執(zhí)行并且 catch 語句塊后的代碼也都不執(zhí)行(遇到 finally 除外)。(見情形一和情形四)
  • 有 try-catch 語句塊,并且 throw 在 try 語句塊里,那么 try 語句塊中引發(fā)異常(報(bào)錯(cuò))的那一行代碼的后續(xù)代碼都不執(zhí)行,但是 catch 語句塊后的代碼會(huì)繼續(xù)執(zhí)行。(見情形二)
  • 有 try-catch 語句塊,但是沒有 throw 語句,那么 try 語句塊中引發(fā)異常(報(bào)錯(cuò))的那一行代碼的后續(xù)代碼都不執(zhí)行,但是 catch 語句塊后的代碼會(huì)繼續(xù)執(zhí)行。(見情形三)
  • 沒有 try-catch 語句塊,單純只有 throw 拋出異常的語句塊,那么 throw 后面的代碼都不執(zhí)行。(見情形五)

下面我們針對(duì) java 拋異常的多種情形分別去研究。

情形一

public class ExceptionTest {
    public static void main(String[] args) {
        String a = null;
        int c = 0, d = 0;
        try {
            int b = a.length();  //null沒有l(wèi)ength()方法,報(bào)空指針異常錯(cuò)誤
            //下面兩條賦值語句不會(huì)執(zhí)行
            c = 1;  
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值為:" + c);
            throw new RuntimeException(e);
        }
        System.out.println("d的值為:" + d);   //本條語句也不執(zhí)行
    }
}

結(jié)果如下:

分析:null 沒有 length() 方法,所以 int b = a.length() 這行代碼會(huì)報(bào)空指針異常的錯(cuò)誤,然后直接跳轉(zhuǎn)到 catch 語句塊去執(zhí)行,打印出 c 的值依舊是 0 ,說明 c=1 沒有執(zhí)行故沒有賦值成功,執(zhí)行完 catch 里的語句后程序就結(jié)束了,System.out.println("d的值為:" + d)這行代碼是不執(zhí)行的,如果想要這行代碼被執(zhí)行,那么可以將其放在 finally 語句塊內(nèi),catch 語句塊執(zhí)行完后就會(huì)執(zhí)行 finally 語句塊。

情形二

public class ExceptionTest {
    public static void main(String[] args) {
        String a = null;
        int c = 0, d = 0;
        try {
            if (a == null) {
                throw new RuntimeException("a的值不能是空");
            }
            //下面兩條賦值語句不會(huì)執(zhí)行
            c = 1;
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值為:" + c); //會(huì)執(zhí)行
            //throw new RuntimeException(e);  //注釋拋異常的函數(shù)
        } 
        System.out.println("d的值為:" + d); //會(huì)執(zhí)行
    }
}

結(jié)果如下:

分析:在 if 里面拋出異常后不再執(zhí)行后面的賦值語句,而是直接跳出 try 語句塊轉(zhuǎn)而進(jìn)入 catch 語句塊,但是該語句塊中拋出異常的函數(shù)已被注釋,所以程序會(huì)繼續(xù)往下執(zhí)行,從而打印出 c 和 d 的初始值 0 。

情形三

public class ExceptionTest {
    public static void main(String[] args) {
        String a = null;
        int c = 0, d = 0;
        try {
            int b = a.length();  //null沒有l(wèi)ength()方法,報(bào)空指針異常錯(cuò)誤
            //下面兩條賦值語句不會(huì)執(zhí)行
            c = 1;
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值為:" + c);
            //throw new RuntimeException(e);   //該行注釋掉
        }
        System.out.println("d的值為:" + d);   //會(huì)執(zhí)行
    }
}

結(jié)果如下:

分析:注釋掉 throw new RuntimeException(e) 這行后,沒有異常拋出,它會(huì)繼續(xù)往下走,因此 d 的值能夠打印出來,但是打印出來的 c 和 d 的值都是初始值 0 ,賦值語句是沒有執(zhí)行成功的。

情形四

public class ExceptionTest {
    public static void main(String[] args) {
        String a = null;
        int c = 0, d = 0;
        try {
            if (a == null) {
                throw new RuntimeException("a的值不能是空");
            }
            //下面兩條賦值語句不會(huì)執(zhí)行
            c = 1;
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值為:" + c); //會(huì)執(zhí)行
            throw new RuntimeException(e);
        }
        System.out.println("d的值為:" + d); //不會(huì)執(zhí)行
    }
}

結(jié)果如下:

分析:先拋出 if 里面的異常,跳過賦值語句的執(zhí)行,直接執(zhí)行 catch 里的代碼,打印出 c 的初始值 0 后又接收到一次異常的拋出, 至此后續(xù)代碼就不會(huì)再執(zhí)行,d 的值也就不可能打印出來。

情形五

public class ExceptionTest {
    public static void main(String[] args) {
        String a = null;
        int c = 0, d = 0;
        if (a == null) {
            System.out.println("c的值為:" + c);
            throw new RuntimeException("字符串a(chǎn)的值不能為空");  //throw語句不在try中
        }
        System.out.println("d的值為:" + d);   //該行代碼不會(huì)執(zhí)行
    }
}

結(jié)果如下:

分析:throw new RuntimeException("字符串a(chǎn)的值不能為空")自定義了拋出的提示信息,可看成是一個(gè) return 返回了相應(yīng)的信息,在拋出異常后其后的代碼不會(huì)再執(zhí)行,因此 d 的值不會(huì)打印出來。

情形六(沒有異常拋出的正常情況)

public class ExceptionTest {
    public static void main(String[] args) {
        String a = "null";
        int c = 0, d = 0;
        try {
            int b = a.length();  //"null"有l(wèi)ength()方法,正常執(zhí)行
            //下面兩條賦值語句會(huì)被執(zhí)行
            c = 1;  
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值為:" + c);
            throw new RuntimeException(e);
        }
        System.out.println("d的值為:" + d);   //本條語句也會(huì)被執(zhí)行
    }
}

結(jié)果如下:

分析:將 null 改為 "null" 后,length() 方法是有效的,此時(shí) int b = a.length() 這行代碼不報(bào)錯(cuò),正常執(zhí)行其后的兩條賦值語句,所以程序不執(zhí)行 catch 中的語句,故不會(huì)打印 c 的值,然后執(zhí)行 System.out.println("d的值為:" + d) 這行代碼,打印出重新賦值后的 d 的值為 2 。

責(zé)任編輯:趙寧寧 來源: 技術(shù)老男孩
相關(guān)推薦

2010-02-01 15:01:34

C++拋出異常

2010-05-05 09:05:07

checked異常

2009-03-18 08:59:28

throw異常Java

2011-05-27 09:10:26

AttachmateSUSENovell

2021-01-13 11:55:39

Spring代碼Java

2025-03-10 01:00:00

Spring參數(shù)解析器

2023-09-25 16:28:35

main函數(shù)C++

2020-09-09 12:49:47

Android Bet開源Android 11

2012-05-29 16:25:45

Transaction

2025-01-09 12:01:53

2024-11-07 11:04:55

2024-02-26 00:00:00

JavaScript單線程高效

2024-06-13 09:30:33

Java線程池線程

2009-12-24 15:04:12

WPF代碼解析異常

2009-04-23 17:59:18

甲骨文SunLinux

2024-10-08 08:00:00

2021-02-25 08:40:19

Java異常分類異常防護(hù)

2014-06-10 10:01:09

HttpClientClose_Wait

2022-06-10 14:09:18

前端監(jiān)控異常數(shù)據(jù)

2012-12-21 10:48:20

Java異常
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)