面向对象—17—运行时异常

本文深入探讨了RuntimeException及其子类的概念,解释了何时使用此类异常,以及如何自定义此类异常。同时,文章还介绍了异常处理机制中的finally代码块的用途,并讨论了异常在子父类覆盖中的表现形式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

/*
Exception中有一个特殊的子类异常RuntimeException(运行时异常).
如果在函数内抛出该异常,函数上可以不用声明,编译一样通过。

如果在函数上声明了该异常,调用者可以不要处理,编译一样通过。

之所以不用在函数上声明,是因为不需要让调用者处理。
当该异常发生,希望程序停止。因为在运行时,出现了无法继续运算
的情况,希望停止后。对代码进行修正。

自定义异常时:如果该异常的方式,无法再进行进行运算,
就让自定义异常继承RuntimeException

对应异常分两种:
1,编译时被检测的异常。
2,编译时不被检测的异常(运行时异常,RuntimeException以及其子类)

*/
class FuShuException extends RuntimeException
{
 FuShuException(String msg)
 {
  super(msg); 
 } 
}

class Demo
{
 int div(int a, int b)//throws ArithmeticException
 {
  if(b<0)
   throw new FuShuException("出现了除数为负数了");
  if(b==0)
   throw new ArithmeticException("被零除了");
  return a/b;
 }
}

class ExceptionDemo4
{
 public static void main(String[] args)
 {
  Demo d = new Demo();
 
  int x = d.div(4,-1);
  System.out.println("x="+x);
  
  System.out.println("over");
 }
}
---------------------------------------------------------------------------------------------

/*
finally 代码块:定义一定执行的代码。
通常用于关闭资源。

第三个格式
try
{}
finally
{}

记住一点:catch是用于处理异常。如果没有catch就代表
异常没有没有被处理过,如果该异常是检测时异常。那么
必须声明。
*/

-------------------------------------------------------------------------------------------

 /*
异常在子父类覆盖中体现:
1,子类在覆盖父类时,如果父类的方法抛出异常,那么子类的
覆盖方法,只能抛出父类异常或者该异常的子类。
2,如果父类方法抛出多个异常,那么子类在覆盖该方法时,
只能抛出父类异常的子集
3,如果父类或者接口的方法中没有异常抛出,那么子类在覆盖
方法时,也不可以抛出异常。如果子类方法发生了异常,就必须要
进行try处理,绝对不能抛。
*/

-----------------------------------------------------------------------------------------------

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值