java异常return在finally前面_java 异常处理

java异常return在finally前面_java 异常处理java 的异常处理机制,执行顺序;return在异常中的使用 ;自定义异常类的简单应用异常处理2种方法:1.抛 (throws)2.自己处理try/catch/finally1.抛出:向上一级抛出,异常实际没有被解决掉2.try/catch/finally(1)正常执行public class Test1 { public static void main(String[] args) { Test1 test1 = new Test1(); test

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

java 的异常处理机制,执行顺序;return在异常中的使用 ;自定义异常类的简单应用
异常处理2种方法:

1.抛 (throws)
2.自己处理try/catch/finally

1.抛出:向上一级抛出,异常实际没有被解决掉

2.try/catch/finally

(1)正常执行

public class Test1 { 
   
    public static void main(String[] args) { 
   
        Test1 test1 = new Test1();
        test1.say();
    }
    public void say() { 
   
        String str = "123";
        try { 
   
        System.out.println(Integer.parseInt(str));
        System.out.println("正常执行");
        //return;
        }catch(Exception e) { 
   
            System.out.println("有异常");
            //return;
        }finally { 
   
            System.out.println("finally");
            //return;
        }
    }
}

复制代码
123
正常执行
finally
(2)异常情况:

复制代码

public class Test1 { 
   
    public static void main(String[] args) { 
   
        Test1 test1 = new Test1();
        test1.say();
    }
    public void say() { 
   
        String str = "abc";
        try { 
   
        System.out.println(Integer.parseInt(str));
        System.out.println("正常执行");
        //return;
        }catch(Exception e) { 
   
            System.out.println("有异常");
            //return;
        }finally { 
   
            System.out.println("finally");
            //return;
        }
    }
}
有异常
finally

结论:finally是一定会被执行的!因此,finally通常用于释放资源,在IO流操作和数据库操作中,程序没有报错,执行了 try 和 finally 代码块,程序报错了,执行try catch finally 代码块

那么这里就有一个问题,执行的先后顺序?

这里我们需要连接一个关键字return!

Java中的return有两方面的用途:

(1)返回方法指定类型的值(前提是方法的返回值类型不是void)。

(2)方法的结束,它会导致当前的方法退出。

通过return我们去探究一下,try catch finally的执行先后顺序!

复制代码

public class Test1 { 
   
    public static void main(String[] args) { 
   
        Test1 test1 = new Test1();
        System.out.println(test1.say());
    }

    public String say() { 
   
        String str = "123";
        try { 
   
            Integer.parseInt(str);
            return "try";
        } catch (Exception e) { 
   

            return "catch";
        } finally { 
   
            return "finally";
        }
    }
}
结果为:finally
public class Test1 { 
   
    public static void main(String[] args) { 
   
        Test1 test1 = new Test1();
        System.out.println(test1.say());
    }

    public String say() { 
   
        String str = "abc";
        try { 
   
            Integer.parseInt(str);
            return "try";
        } catch (Exception e) { 
   

            return "catch";
        } finally { 
   
            return "finally";
        }
    }
}
结果也是finally

这是为什么?finally是必定执行的代码块!所有finally逻辑上虽然能使用return,但一般finally不会接return。否则你什么也测不出来

public class Test1 { 
   
    public static void main(String[] args) { 
   
        Test1 test1 = new Test1();
        System.out.println(test1.say());
    }

    public String say() { 
   
        String str = "abc";
        try { 
   
            Integer.parseInt(str);
            return "try";
        } catch (Exception e) { 
   
            System.out.println("catch");
            return "catch";
        } finally { 
   
            System.out.println("finally");
        }
    }
}
catch
finally
catch

由此可以看出执行的顺序为:

(1)Integer.parseInt(str);
(2)System.out.println(“catch”);
(3)System.out.println(“finally”);
(4)return “catch”;
同理其他:
复制代码

public class Test1 { 
   
    public static void main(String[] args) { 
   
        Test1 test1 = new Test1();
        System.out.println(test1.say());
    }

    public String say() { 
   
        String str = "abc";
        try { 
   
            Integer.parseInt(str);
            return "try";
        } catch (Exception e) { 
   
            System.out.println("catch");
            return "catch";
        } finally { 
   
            System.out.println("finally");
            return "finally + return";
        }
    }
}

复制代码

catch
finally
finally + return
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168700.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月8日 下午4:46
下一篇 2022年8月8日 下午4:46


相关推荐

  • 安装Pytorch-gpu版本(第一次安装 或 已经安装Pytorch-cpu版本后)

    安装Pytorch-gpu版本(第一次安装 或 已经安装Pytorch-cpu版本后)由于已经安装了cpu版本了,如果再在该环境下安装gpu版本会造成环境污染.因此,再安装gpu版本时,需要再新建一个虚拟环境才能安装成功。然后去官网下载所适配的版本。安装完cuda和cudnn后,开始安装pytorch的gpu版本。1.安装cude首先查看windows电脑之前是否成功安装了CUDA第一步:同时按键盘上的“windows键+R”,输入“cmd”并回车,进入windows的命令行界面。第二步:命令行里输入“nvcc-V”并回车第三步:如果已经成功安装CUDA的话,.

    2022年10月6日
    6
  • 机器学习和深度学习的区别

    机器学习和深度学习的区别Python 微信订餐小程序课程视频 https edu csdn net course detail 36074Python 实战量化交易理财系统 https edu csdn net course detail 35475 终于考上人工智能的研究僧啦 不知道机器学习和深度学习有啥区别 感觉一切都是深度学习挖槽 听说学长已经调了 10 个月的参数准备发有 2000 亿参数的 T9 开天霹雳模型 我要调参发 T10 准备拿个 BestPaper 现在搞传统机器学习相关的研究论文确实占比不太高 有的人吐槽深度学

    2026年3月19日
    2
  • sql 存储过程 变量赋值

    sql 存储过程 变量赋值1 获得查询结果影响的行数 select fromSMS DateReportif ROWCOUNT0 PRINTN 影响 1 行以上 elsePRINTN 影响 0 行 2 查询结果赋值给变量 nbsp DECLARE dtTempdateti nbsp DECLARE dtStart nbsp datetime nbsp DECLARE vcdtvarchar 50

    2026年3月26日
    2
  • 两位8421BCD码加法器的设计与实现

    两位8421BCD码加法器的设计与实现南通大学计算机科学与技术学院计算机组成原理 实验报告 实验名称两位 8421BCD 码加法器的设计与实现班级学号姓名 jontyy 指导教师

    2026年3月16日
    2
  • 信号处理之父_信息与信号处理

    信号处理之父_信息与信号处理一、DFT之前言部分由于matlab已提供了内部函数来计算DFT、IDFT,我们只需要会调用fft、ifft函数就行;二、函数说明:fft(x):计算N点的DFT。N是序列x的长度,即N=len

    2022年8月6日
    9
  • clion 2021.3激活码破解方法

    clion 2021.3激活码破解方法,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    290

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号