亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2023年07月25日 14:43:23   作者:【金融科技螞蟻】  
這篇文章主要給大家介紹了關(guān)于java拋出異常后,后續(xù)代碼是否繼續(xù)執(zhí)行詳?shù)南嚓P(guān)資料,在Java編程中,異常是當(dāng)程序執(zhí)行時(shí)遇到問(wèn)題時(shí)拋出的一種特殊情況,需要的朋友可以參考下

前言

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

1、有 try-catch 語(yǔ)句塊,并且 throw 在 catch 語(yǔ)句塊里,那么 try 語(yǔ)句塊中引發(fā)異常(報(bào)錯(cuò))的那一行代碼的后續(xù)代碼都不執(zhí)行并且 catch 語(yǔ)句塊后的代碼也都不執(zhí)行(遇到 finally 除外)。(見情形一和情形四)

2、有 try-catch 語(yǔ)句塊,并且 throw 在 try 語(yǔ)句塊里,那么 try 語(yǔ)句塊中引發(fā)異常(報(bào)錯(cuò))的那一行代碼的后續(xù)代碼都不執(zhí)行,但是 catch 語(yǔ)句塊后的代碼會(huì)繼續(xù)執(zhí)行。(見情形二)

3、有 try-catch 語(yǔ)句塊,但是沒有 throw 語(yǔ)句,那么 try 語(yǔ)句塊中引發(fā)異常(報(bào)錯(cuò))的那一行代碼的后續(xù)代碼都不執(zhí)行,但是 catch 語(yǔ)句塊后的代碼會(huì)繼續(xù)執(zhí)行。(見情形三)

4、沒有 try-catch 語(yǔ)句塊,單純只有 throw 拋出異常的語(yǔ)句塊,那么 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ò)誤
            //下面兩條賦值語(yǔ)句不會(huì)執(zhí)行
            c = 1;  
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值為:" + c);
            throw new RuntimeException(e);
        }
        System.out.println("d的值為:" + d);   //本條語(yǔ)句也不執(zhí)行
    }
}

結(jié)果如下:

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

情形二:

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的值不能是空");
            }
            //下面兩條賦值語(yǔ)句不會(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í)行后面的賦值語(yǔ)句,而是直接跳出 try 語(yǔ)句塊轉(zhuǎn)而進(jìn)入 catch 語(yǔ)句塊,但是該語(yǔ)句塊中拋出異常的函數(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ò)誤
            //下面兩條賦值語(yǔ)句不會(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 的值能夠打印出來(lái),但是打印出來(lái)的 c 和 d 的值都是初始值 0 ,賦值語(yǔ)句是沒有執(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的值不能是空");
            }
            //下面兩條賦值語(yǔ)句不會(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 里面的異常,跳過(guò)賦值語(yǔ)句的執(zhí)行,直接執(zhí)行 catch 里的代碼,打印出 c 的初始值 0 后又接收到一次異常的拋出, 至此后續(xù)代碼就不會(huì)再執(zhí)行,d 的值也就不可能打印出來(lái)。

情形五:

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語(yǔ)句不在try中
        }
        System.out.println("d的值為:" + d);   //該行代碼不會(huì)執(zhí)行
    }
}

結(jié)果如下:

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

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

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í)行
            //下面兩條賦值語(yǔ)句會(huì)被執(zhí)行
            c = 1;  
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值為:" + c);
            throw new RuntimeException(e);
        }
        System.out.println("d的值為:" + d);   //本條語(yǔ)句也會(huì)被執(zhí)行
    }
}

結(jié)果如下:

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

總結(jié)

到此這篇關(guān)于java拋出異常后,后續(xù)代碼是否繼續(xù)執(zhí)行的文章就介紹到這了,更多相關(guān)java拋出異常是否繼續(xù)執(zhí)行內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MyBatis-plus實(shí)現(xiàn)逆向生成器

    MyBatis-plus實(shí)現(xiàn)逆向生成器

    本文主要介紹了MyBatis-plus實(shí)現(xiàn)逆向生成器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Mybatis關(guān)聯(lián)查詢遇到的坑-無(wú)主鍵的關(guān)聯(lián)數(shù)據(jù)去重問(wèn)題

    Mybatis關(guān)聯(lián)查詢遇到的坑-無(wú)主鍵的關(guān)聯(lián)數(shù)據(jù)去重問(wèn)題

    這篇文章主要介紹了Mybatis關(guān)聯(lián)查詢遇到的坑-無(wú)主鍵的關(guān)聯(lián)數(shù)據(jù)去重問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Jackson2的JsonSchema實(shí)現(xiàn)java實(shí)體類生成json方式

    Jackson2的JsonSchema實(shí)現(xiàn)java實(shí)體類生成json方式

    這篇文章主要介紹了Jackson2的JsonSchema實(shí)現(xiàn)java實(shí)體類生成json,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • java Timer測(cè)試定時(shí)調(diào)用及固定時(shí)間執(zhí)行代碼示例

    java Timer測(cè)試定時(shí)調(diào)用及固定時(shí)間執(zhí)行代碼示例

    這篇文章主要介紹了java Timer測(cè)試定時(shí)調(diào)用及固定時(shí)間執(zhí)行代碼示例,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • Netty分布式ByteBuf的分類方式源碼解析

    Netty分布式ByteBuf的分類方式源碼解析

    這篇文章主要為大家介紹了Netty分布式ByteBuf的分類方式源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-03-03
  • MyBatis快速入門

    MyBatis快速入門

    MyBatis是支持普通SQL查詢,存儲(chǔ)過(guò)程和高級(jí)映射的優(yōu)秀持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數(shù)的手工設(shè)置以及結(jié)果集的檢索。想要學(xué)好它,那就要從MyBatis基礎(chǔ)知識(shí)學(xué)起,下面跟著小編一起來(lái)看下吧
    2017-03-03
  • Java 使用keytool創(chuàng)建CA證書的操作

    Java 使用keytool創(chuàng)建CA證書的操作

    這篇文章主要介紹了Java 使用keytool創(chuàng)建CA證書的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • 解析Spring Boot內(nèi)嵌tomcat關(guān)于getServletContext().getRealPath獲取得到臨時(shí)路徑的問(wèn)題

    解析Spring Boot內(nèi)嵌tomcat關(guān)于getServletContext().getRealPath獲取得到臨時(shí)

    大家都很糾結(jié)這個(gè)問(wèn)題在使用getServletContext().getRealPath()得到的是臨時(shí)文件的路徑,每次重啟服務(wù),這個(gè)臨時(shí)文件的路徑還好變更,下面小編通過(guò)本文給大家分享Spring Boot內(nèi)嵌tomcat關(guān)于getServletContext().getRealPath獲取得到臨時(shí)路徑的問(wèn)題,一起看看吧
    2021-05-05
  • MyBatis-Plus3.x版本使用入門和踩過(guò)的坑

    MyBatis-Plus3.x版本使用入門和踩過(guò)的坑

    Mybatis-Plus是Mybatis的增強(qiáng)版,他只是在Mybatis的基礎(chǔ)上增加了功能,且并未對(duì)原有功能進(jìn)行任何的改動(dòng),本文給大家說(shuō)一下MyBatis-Plus3.x版本使用入門和踩過(guò)的坑,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • Java底層基于鏈表實(shí)現(xiàn)集合和映射--集合Set操作詳解

    Java底層基于鏈表實(shí)現(xiàn)集合和映射--集合Set操作詳解

    這篇文章主要介紹了Java底層基于鏈表實(shí)現(xiàn)集合和映射集合Set操作,結(jié)合實(shí)例形式詳細(xì)分析了Java使用鏈表實(shí)現(xiàn)集合和映射相關(guān)原理、操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2020-03-03

最新評(píng)論