异常处理2

本文详细解析Java中异常处理机制,特别强调了RuntimeException及其子类的使用场景,以及如何在自定义异常中继承RuntimeException以实现特定的异常处理逻辑。同时,通过实例演示了如何在函数中正确声明和抛出自定义异常,并讨论了调用者在面对此类异常时的处理方式。

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

/*
Execption中有一个特殊的子类异常RuntimeException运行时异常。


如果在函数内抛出该异常,函数上可以不用声明,编译一样通过。


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


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




自定义异常时:如果该异常的发生,无法再继续运算,就让自定义异常继承RuntimeException。


1.编译时被检测的异常。
2,编译时不被检测的异常(运行时异常。RuntimeException以及其子类)
凡是调用RuntimeException的都是希望程序停止下来。
如果希望修正代码时,希望程序停止下来继承RuntimeException
如果这个程序发生异常后,可以运行,继承Exception



*/


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


class Demo
{
int div(int a,int b)//如果下面抛出的是Exception,则这里必须throws Exception,且调用者也必须声明,要么抛要么停止程序。这时编译时检测的异常。
{
if(b<0)
throw new FuShuException("出现了除数为负数了");//如果这里是Exception则函数应声明Exception
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,-9);
System.out.println("x="+x);
System.out.println("over");


}
}




/*


class Person
{
public void checkName(String name)
{
//if(name.equals("lisi"))//NullPonitException
if("lisi".equals(name))//这个就没问题,lisi调用方法,和null比较,而不是上面的null调用方法。
// if(name!=null && name.equals("lisi"))
System.out.println("YES");
else
System.out.println("NO");
}


}
main()
{
Person p = new Person();
p.checkName(null);//如果传空的话,空值是不能作比较的。
}


*/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值