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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 更新源metaspolit报错GPG Error「建议收藏」

    更新源metaspolit报错GPG Error「建议收藏」通过msfupdate无法更新到最新版本,需首先更新系统源:)更新系统源报错,提示metaspolitGPGerror:解决方案:输入以下两条命令1、sudoecho‘debhttp://apt.metasploit.com/lucidmain’>/etc/apt/sources.list.d/metasploit-framework.list2、sudowge…

    2022年10月9日
    11
  • [Unity3D]Unity3D游戏开发之ACT游戏三连击效果实现综述

    [Unity3D]Unity3D游戏开发之ACT游戏三连击效果实现综述

    2021年12月14日
    65
  • 最小二乘法详细推导过程

    最小二乘法详细推导过程转载自:http://blog.csdn.net/marsjohn/article/details/54911788在数据的统计分析中,数据之间即变量x与Y之间的相关性研究非常重要,通过在直角坐标系中做散点图的方式我们会发现很多统计数据近似一条直线,它们之间或者正相关或者负相关。虽然这些数据是离散的,不是连续的,我们无法得到一个确定的描述这种相关性的函数方程,但既然在直角坐标系中数据分布接近一…

    2022年5月13日
    34
  • ghost备份系统有什么用_win备份和ghost备份的区别

    ghost备份系统有什么用_win备份和ghost备份的区别  Ghost(是GeneralHardwareOrientedSoftwareTransfer的缩写译为“面向通用型硬件系统传送器”)软件是美国赛门铁克公司推出的一款出色的硬盘备份还原工具,可以实现FAT16、FAT32、NTFS、OS2等多种硬盘分区格式的分区及硬盘的备份还原。俗称克隆软件。  1、特点:既然称之为克隆软件,说明其Ghost的备份还原是以硬盘的扇区为单位进行的

    2025年9月16日
    9
  • native DRAMAtical Murder_project diablo 2

    native DRAMAtical Murder_project diablo 2投影投影是JMESPath的关键特性之一。它允许您将表达式应用于元素集合。有五种投影:列表投影切片投影对象投影展平投影过滤投影处理投影需要注意的点投影分为两个步骤。左侧(LHS)创建一

    2022年7月29日
    8
  • 从MVC框架看MVC架构的设计

    从MVC框架看MVC架构的设计尽管MVC早已不是什么新鲜话题了,但是从近些年一些优秀MVC框架的设计上,我们还是会发现MVC在架构设计上的一些新亮点。本文将对传统MVC架构中的一些弊病进行解读,了解一些优秀MVC框架是如何化解这些问题的,揭示其中所折射出的设计思想与设计理念。MVC回顾作为一种经典到不能再经典的架构模式,MVC的成功有其必然的道理,这个道理不同的人会有不同的解读,笔者最认同的一种观

    2022年4月7日
    38

发表回复

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

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