try,catch,finally使用,代码演示

01 jdk1.7异常的处理方式
不需要手动关闭流 因为会自动关闭流

因为FileInputStream 和FileOutPutStream都实现了AutoCloseable接口
这个接口中的close()方法具有自动关闭的功能
想要具有自动关系的功能 , 格式必须按照下面的格式写

在这里插入图片描述


02 模仿自动关闭流

       实现AutoCloseable接口  重写close()方法
      按照格式写好流操作
      执行  ,就会发现close()方法会自动执行

在这里插入图片描述

输出
这里是流操作
这里关闭流


01 try{…} catch(){…}

cathc(){}后面的代码也会执行

在这里插入图片描述


02 捕获有异常的方法

在这里插入图片描述


03 处理多个异常 第一种 多个try{}catch{}

在这里插入图片描述


03 处理多个异常 第二种 一个try{}多个catch{}

        如catch的异常有子父类关系  子类异常写前面 父类异常写后面  否则报异常
       根据里氏代换原则 , 能使用父类型地方一定能使用子类(子类)

在这里插入图片描述


03 处理多个异常 第三种 使用 | 捕获多个异常

       jdk1.7版本后写法

在这里插入图片描述


try{…} final{…}

     不管try里面有没有异常  finally都会执行

在这里插入图片描述


使用throw的缺点 如果发生异常 异常后面的代码不会再执行
使用try{} catch{}捕获异常 try{}里面异常后面的代码不能执行
但是catch{}里面或finally{}里面或者finally{}后面的代码都可以执
finally{}不能单独使用 多数用于资源的释放


01 无论是否有异常finally都会执行

在这里插入图片描述


02 try{…} chath(){…} finally{…}

try{}或catch{}中有return finaly也一定会执行
除非在finally虚拟机退出了,例如Sysytem.exit(0)
如果try或catch里面有return语句,先执行try或catch里的,在retrun前执行finally


如果finally没有return 但是有修改返回值, 修改的没有用 还是返回以前的值
在这里插入图片描述

输出
一定会执行
10


如果finally中有return ,并且修改了返回值, 那么就返回修改的值
在这里插入图片描述

输出
一定会执行
11


03 异常中的代码是否能执行
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在前端开发中,try-catch-finally是一种异常机制。它允许我们在代码中捕获和处理可能出现的错误或异常,以便更好地控制程序的执行流程。 try-catch-finally的基本语法如下: ```javascript try { // 可能会抛出异常代码块 } catch (error) { // 异常处理逻辑 } finally { // 无论是否发生异常,都会执行的代码块 } ``` 在try块中,我们可以放置可能会抛出异常代码。如果在try块中发生了异常,那么程序会立即跳转到catch块,并执行其中的代码catch块中的参数error表示捕获到的异常对象,我们可以通过它来获取异常的相关信息。 无论是否发生异常finally块中的代码都会被执行。它通常用于释放资源或执行一些必要的清理操作,比如关闭文件、断开数据库连接等。 下面是一个简单的示例,演示try-catch-finally使用: ```javascript try { // 可能会抛出异常代码 const result = 10 / 0; // 除以0会抛出异常 console.log(result); // 这行代码不会被执行 } catch (error) { // 异常处理逻辑 console.error('发生了一个错误:', error); } finally { // 清理操作 console.log('无论是否发生异常,这里的代码都会执行'); } ``` 在上面的示例中,由于除以0是一个非法操作,会抛出一个异常。程序会跳转到catch块中,打印出错误信息。最后,无论是否发生异常finally块中的代码都会被执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值