java api中的异常处理

 首先我们要知道java中异常分为编译时异常和运行时异常。

这里的编译时异常可以理解为错误,即一些基本的语法错误。无法通过编译的,这里我们一般不做深究。

我们的主角还是--运行时异常。首先我们要知道最基本的就是如何来处理异常。

一异常的捕获。

try catch finally便是我们处理异常的方法。我们将可能出现异常的代码放在try块。将出现异常后处理的代码放在catch块。finally则是无论是否有异常产生,都会执行的。我们现在可以来讨论一下它们的执行顺序。当try块中的代码块有异常时会即刻停止执行try中的语句进入到catch块中。然后再执行finally块。如图:

这里由于a/b的除数等于0,编译时会发生错误。于是就会进入到catch块中。

当我们改正后:

catch块中的语句并不会执行了。

接下来我们来看看多层catch语句。多层catch是用来分别捕获不同的数据的异常,对于不同类型的异常做不同的处理。虽然多层catch可以同时监听多种不同类型的异常,但是try块中一旦有某个异常产生,程序就会跳转到对应的catch中执行,然后执行后面的代码。多层catch只会捕捉到最先产生的异常,而不是所有异常全部捕捉,即多层catch中最多只有一个catch执行。这里有一点需要特别注意(catch块的书写顺序:类层次越高,越把它写在catch块的后面  关于层次建议去api文档中查看一下异常)如图:

这里我们可以很明显的看出来 a/b的除数为0,编译时会发生错误。arr[3] 超过了数组的边界也编译时错误,但很明显,这里我们并没有进入到越界的catch块去。

下面看一下try catch finally 带return的情况下的执行情况。这里先说一下,先执行try块中的语句,接着执行finally中的语句,接着再执行try中的return。上图:

 看如图的代码我们可以知道它的结果是2。但它怎么来的呢?首先num1 和 num2 num3都是int型

我们应该都知道8种原始类型都是存在栈中的。执行try块是num3回等于num1/num2得到2,此时会先将num3的值临时存放起来(可以想象成int temp = num3)。当我们再执行finally块时,num3 = 12,接着再执行try中的return语句。重点,这里return的是我们刚刚存起来的num3 即temp,所以可知这段代码执行结果为2。

我们刚刚说了int型存在栈中,如果不是8大原始数据类型,存在堆中的数据呢?

这段代码的执行结果为Hello hhq! 是不是看着与我们前面的相违背了?并没有。StringBuffer 是在堆中申请空间,sbf存放的是地址。这里也可以看出temp = sbf,但这个temp还是会指向Hello。如图:

 所以当我们的finally语句改变sbf时,我们的temp也会跟着改变。

二抛出异常

如果某个方法中的代码有可能引发异常,可以使用try、catch在方法内部处理,也可以使用throws向方法外抛出异常。

throws也可以同时抛出多个异常,抛出的异常类层次越高的越往后写,跟多层catch一样。

注意:重写方法时,抛出的异常必须跟父类中方法抛出的一样一致或能进行引用转型(子类抛出异常可以是父类抛出的异常的子类)或不抛出异常。

throw用来手动抛出异常。

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值