java抛出异常后,后续代码是否继续执行

这篇具有很好参考价值的文章主要介绍了java抛出异常后,后续代码是否继续执行。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

        java 抛出异常后,后面的语句到底是怎么执行的呢?哪些会继续执行,哪些不再执行,这是本章要探讨的问题。为方便广大友友解决问题,先把结论丢出来:

1、有 try-catch 语句块,并且 throw 在 catch 语句块里,那么 try 语句块中引发异常(报错)的那一行代码的后续代码都不执行并且 catch 语句块后的代码也都不执行(遇到 finally 除外)。(见情形一和情形四)

2、有 try-catch 语句块,并且 throw 在 try 语句块里,那么 try 语句块中引发异常(报错)的那一行代码的后续代码都不执行,但是 catch 语句块后的代码会继续执行。(见情形二)

3、有 try-catch 语句块,但是没有 throw 语句,那么 try 语句块中引发异常(报错)的那一行代码的后续代码都不执行,但是 catch 语句块后的代码会继续执行。(见情形三)

4、没有 try-catch 语句块,单纯只有 throw 抛出异常的语句块,那么 throw 后面的代码都不执行。(见情形五)

       下面我们针对 java 抛异常的多种情形分别去研究。

情形一:

public class ExceptionTest {
    public static void main(String[] args) {
        String a = null;
        int c = 0, d = 0;
        try {
            int b = a.length();  //null没有length()方法,报空指针异常错误
            //下面两条赋值语句不会执行
            c = 1;  
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值为:" + c);
            throw new RuntimeException(e);
        }
        System.out.println("d的值为:" + d);   //本条语句也不执行
    }
}

结果如下:

java throw后的代码继续执行,java后端项目,java,jvm,spring boot,开发语言,intellij-idea

       分析:null 没有 length() 方法,所以 int b = a.length() 这行代码会报空指针异常的错误,然后直接跳转到 catch 语句块去执行,打印出 c 的值依旧是 0 ,说明 c=1 没有执行故没有赋值成功,执行完 catch 里的语句后程序就结束了,System.out.println("d的值为:" + d)这行代码是不执行的,如果想要这行代码被执行,那么可以将其放在 finally 语句块内,catch 语句块执行完后就会执行 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的值不能是空");
            }
            //下面两条赋值语句不会执行
            c = 1;
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值为:" + c); //会执行
            //throw new RuntimeException(e);  //注释抛异常的函数
        } 
        System.out.println("d的值为:" + d); //会执行
    }
}

结果如下:

java throw后的代码继续执行,java后端项目,java,jvm,spring boot,开发语言,intellij-idea

        分析:在 if 里面抛出异常后不再执行后面的赋值语句,而是直接跳出 try 语句块转而进入 catch 语句块,但是该语句块中抛出异常的函数已被注释,所以程序会继续往下执行,从而打印出 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没有length()方法,报空指针异常错误
            //下面两条赋值语句不会执行
            c = 1;
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值为:" + c);
            //throw new RuntimeException(e);   //该行注释掉
        }
        System.out.println("d的值为:" + d);   //会执行
    }
}

 结果如下:

java throw后的代码继续执行,java后端项目,java,jvm,spring boot,开发语言,intellij-idea

       分析: 注释掉 throw new RuntimeException(e) 这行后,没有异常抛出,它会继续往下走,因此 d 的值能够打印出来,但是打印出来的 c 和 d 的值都是初始值 0 ,赋值语句是没有执行成功的。

情形四:

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的值不能是空");
            }
            //下面两条赋值语句不会执行
            c = 1;
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值为:" + c); //会执行
            throw new RuntimeException(e);
        }
        System.out.println("d的值为:" + d); //不会执行
    }
}

结果如下:

java throw后的代码继续执行,java后端项目,java,jvm,spring boot,开发语言,intellij-idea

       分析:先抛出 if 里面的异常,跳过赋值语句的执行,直接执行 catch 里的代码,打印出 c 的初始值 0 后又接收到一次异常的抛出, 至此后续代码就不会再执行,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的值不能为空");  //throw语句不在try中
        }
        System.out.println("d的值为:" + d);   //该行代码不会执行
    }
}

结果如下:

java throw后的代码继续执行,java后端项目,java,jvm,spring boot,开发语言,intellij-idea

       分析:throw new RuntimeException("字符串a的值不能为空")自定义了抛出的提示信息,可看成是一个 return 返回了相应的信息,在抛出异常后其后的代码不会再执行,因此 d 的值不会打印出来。

情形六(没有异常抛出的正常情况):

public class ExceptionTest {
    public static void main(String[] args) {
        String a = "null";
        int c = 0, d = 0;
        try {
            int b = a.length();  //"null"有length()方法,正常执行
            //下面两条赋值语句会被执行
            c = 1;  
            d = 2;
        } catch (Exception e) {
            System.out.println("c的值为:" + c);
            throw new RuntimeException(e);
        }
        System.out.println("d的值为:" + d);   //本条语句也会被执行
    }
}

结果如下:

java throw后的代码继续执行,java后端项目,java,jvm,spring boot,开发语言,intellij-idea

       分析:将 null 改为 "null" 后,length() 方法是有效的,此时 int b = a.length() 这行代码不报错,正常执行其后的两条赋值语句,所以程序不执行 catch 中的语句,故不会打印 c 的值,然后执行 System.out.println("d的值为:" + d) 这行代码,打印出重新赋值后的 d 的值为 2 。文章来源地址https://www.toymoban.com/news/detail-586676.html

到了这里,关于java抛出异常后,后续代码是否继续执行的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 详解Java中的异常体系结构(throw,throws,try-catch,finally,自定义异常)

    目录 一.异常的概念 二.异常的体系结构 三.异常的处理 异常处理思路 LBYL:Look Before You Leap EAFP: It\\\'s Easier to Ask Forgiveness than Permission 异常抛出throw 异常的捕获 提醒声明throws  try-catch捕获处理 finally的作用 四.自定义异常类 有一句话说的很好 ”程序员不是在写BUG就是在改BUG”

    2024年02月05日
    浏览(41)
  • 【C++】异常处理 ① ( 异常概念引入 | 抛出异常语法 | 捕获异常语法 | 异常捕获流程 | 异常处理代码示例 )

    异常是一种 特殊的程序流控制机制 , 用于处理程序中可能出现的错误或异常情况 ; 当程序执行错误时 , 由 throw 抛出异常 , 并即跳转到相应的异常处理程序中 ; 如果没有适当的异常处理程序处理该异常 , 程序会崩溃终止 ; 异常与函数对比 : 函数 是一种 以 栈结构 展开的

    2024年02月04日
    浏览(52)
  • java~用泛型来定义异常类型,避免方法调用时throws异常

    我们一般在底层写方法时,如果方法显示throws异常,那么在调用时,也需要将这个异常throws出来,例如 调用时 如果调用时不显示throws出异常,编译器会报出错误,如下图 调用方法时,不需要再throws Ex了,这种对调用者更友好,如图 在第一个方法中,使用了泛型类型 来定义

    2024年02月21日
    浏览(40)
  • 微信小程序等待wx.requestPayment的回调函数执行完后再执行后续代码

    在开发微信小程序过程中,遇到如下需求: 需要等待wx.requestPayment的回调函数执行完后再执行后续代码 这是因为在调用wx.requestPayment之后,会弹出一个支付弹窗,如果此时点击右上角的 x ,那么将会执行wx.requestPayment的回调函数fail中的代码。而由于 wx.requestPayment 的回调函数是

    2024年02月09日
    浏览(42)
  • java try throw exception finally 遇上 return break continue造成异常丢失

        如下所示,是一个java笔试题,考察的是抛出异常之后,程序运行结果,但是这里抛出异常,并没有捕获异常,而是通过finally来进行了流程控制处理。     运行程序,打印结果如下所示:       这里结果有些出人意料,并没有打印异常信息,其实就是try finally遇到了con

    2024年02月08日
    浏览(45)
  • OkHttp抛出异常java.net.ProtocolException: unexpected end of stream

    今天用okHttp写了个从本地的Apache服务器上下载资源的安卓app,然后发现偶尔的下载会抛出java.net.ProtocolException: unexpected end of stream的异常,苦思不得结果后上百度查找,百度有很多分析,有可能的原因是响应头Content-length和实体长度不同,找到几个方法,有的说在请求头中添加

    2024年02月16日
    浏览(52)
  • 由于找不到VCRUNTIMEE1400.dll,无法继续执行代码,以及由于找不到ucrtbased.dll,无法继续执行代码 彻底解决,多种方法(本人亲测有效)

     这些文件我上传到网盘,有需要去网盘下载,下载链接如下: 链接:https://pan.baidu.com/s/1e3loCUx_eVBaa2p3jf-svw  提取码:2023 以上这几个文件, 看系统错误说是缺少啥文件就去网盘下载 , 注意是什么文件缺少,别看错了 ,然后把相关缺少的文件分别放在 C:WindowsSystem32      和

    2024年02月20日
    浏览(76)
  • 由于找不到vcruntime140.dll无法继续执行代码

    电脑在打开软件或者游戏游戏的时候,提示由于找不到vcruntime140.dll无法继续执行代码。这个主要的原因是电脑系统中的vcruntime140.dll丢失了或者被损坏了。vcruntime140.dll文件是电脑系统中非常重要的文件,我们需要如何修复呢?小编今天就把教程分享给大家;   首先是打开电脑

    2024年02月08日
    浏览(62)
  • 解决找不到vcruntime140.dll,无法继续执行代码方法

    在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是“找不到vcruntime140.dll”。这个错误通常发生在运行某些程序或游戏时,它会导致程序无法正常启动或运行。那么,找不到vcruntime140.dll,无法继续执行代码是什么原因造成的呢?本文将从多个方面进行详细分

    2024年02月08日
    浏览(69)
  • 找不到msvcp140.dll无法继续执行代码,怎么解决?

    MSVCP140.dll是一个Windows操作系统中的动态链接库文件,它是Microsoft Visual C++ Redistributable for Visual Studio 2015的一部分。这些库提供了一些C++程序所需的基本功能,例如内存管理、文件操作、字符串处理等等。丢失或者损坏会导致很多软件跟游戏无法打开运行,小编今天就把解决方

    2024年02月10日
    浏览(86)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包