时间:2021-05-19
① try-catch-finally
② throws
① 自动抛出
可以理解为所有没有使用throw关键字的异常处理都是自动抛出,由jvm进行判断和抛出。
②手动抛出
throw + 异常类的对象
》异常类可以是现成的,也可以是自己创建的异常类,
抛出异类的类型:若是RuntimException,可以不用显示处理。
若是一个Exception,必须要显示的处理。
/* *1.手动抛出一个异常的例子 */public class TestException3 { public static void main(String[] args) { Circle c1 = new Circle(2.1); Circle c2 = new Circle(2.1); System.out.println(c2.compareTo(c2)); System.out.println(c1.compareTo(new String("44"))); }}class Circle{ private double radius; public Circle(double radius) { super(); this.radius = radius; } public double getRadius() { return radius; } public void setRadius(double radius) { this.radius = radius; } //比较两个圆的半径谁大 public int compareTo(Object obj) { if(this == obj) { return 0; } else if(obj instanceof Circle) { Circle c = (Circle)obj; if(this.radius > c.radius) { return 1; }else if(this.radius == c.radius){ return 0; }else { return -1; } }else { //因为在这里返回声明都不适合,手动的抛出一个异常 //运行时异常可以不用显示处理,在运行的时候,抛出。 throw new RuntimeException("传入的类型有误");// throw new Exception("传入的类型有误"); //非RuntimeException必须在出现的时候显示处理 } }}补充:java中异常抛出后代码还会继续执行吗?
今天遇到一个问题,在下面的代码中,当抛出运行时异常后,后面的代码还会执行吗,是否需要在异常后面加上return语句呢?
@Override public void registerObserver(Observer o) { if (o == null){ throw new NullPointerException("o is a null object"); return; //需要么? } this.mList.add(o); }为了搞清楚这个问题,我编写了几段代码测试了一下,结果如下:
//代码1public static void test() throws Exception { throw new Exception("参数越界"); System.out.println("异常后"); //编译错误,「无法访问的语句」}//代码2try{ throw new Exception("参数越界"); }catch(Exception e) { e.printStackTrace();}System.out.println("异常后");//可以执行//代码3if(true) { throw new Exception("参数越界"); }System.out.println("异常后"); //抛出异常,不会执行1、若一段代码前有异常抛出,并且这个异常没有被捕获,这段代码将产生编译时错误「无法访问的语句」。如代码1;
2、若一段代码前有异常抛出,并且这个异常被try…catch所捕获,若此时catch语句中没有抛出新的异常,则这段代码能够被执行,否则,同第1条。如代码2;
3、若在一个条件语句中抛出异常,则程序能被编译,但后面的语句不会被执行。如代码3
运行时异常是RuntimeException类及其子类的异常,是非受检异常,如NullPointerException、IndexOutOfBoundsException等。由于这类异常要么是系统异常,无法处理,如网络问题;要么是程序逻辑错误,如空指针异常;JVM必须停止运行以改正这种错误,所以运行时异常可以不进行处理(捕获或向上抛出,当然也可以处理),而由JVM自行处理。Java Runtime会自动catch到程序throw的RuntimeException,然后停止线程,打印异常。
非运行时异常是RuntimeException以外的异常,类型上都属于Exception类及其子类,是受检异常。非运行时异常必须进行处理(捕获或向上抛出),如果不处理,程序将出现编译错误。一般情况下,API中写了throws的Exception都不是RuntimeException。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言有时候python自带异常不够用,如同java,python也可以自定义异常,并且可以手动抛出。注意,自定义异常只能由自己抛出。python解释器是不知道用
我当初学java异常处理的时候,对于父子异常的处理,我记得几句话“子类方法只能抛出父类方法所抛出的异常或者是其子异常,子类构造器必须要抛出父类构造器的异常或者其
java中的异常涉及到父子类的问题,可以归纳为一句话:子类的构造函数抛出的异常必须包含父类的异常,子类的方法可以选择抛出“范围小于等于”父类的异常或不抛出异常。
本文实例讲述了Java抛出异常与自定义异常类。分享给大家供大家参考,具体如下:异常处理常用方法:常用的异常处理方法有:一、try()catch()语句二、thr
任何Java代码都可以抛出异常,如:自己编写的代码、来自Java开发环境包中代码,或者Java运行时系统。无论是谁,都可以通过Java的throw语句抛出异常。