package ThrowableTest; /** *自定义异常只需要继承Exception或者RuntimeException噙着为编译时异常 后者为运行时异常 *然后定义一个无参和一个有参的构造器,这个有参的构造器将作为对异常对象的描述信息也就是异常对象的getMessage() */ class MyException extends Exception{ public MyException(String name){ super(name); } } class Person { private int weight; public Person(int weight)throws MyException{ if(weight<0||weight>300){ /* * 抛出的为编译时类型异常所以,throw语句要么放在 try语句块中,显示捕获该异常,要么放在一个带throws生命抛出的方法中 * */ throw new MyException("体重输入非法异常"); } this.weight=weight; } public int getWeight() { return weight; } } public class MyThreadTest { public static void main(String[] args) throws MyException { //第一种处理方式 try { /*该构造方法可能会自动抛出编译时异常,现在是放进了try块中,并且显示捕捉该异常 */ Person person1 = new Person(400); }catch (MyException e1){ e1.printStackTrace(); } //第二种处理方式 /*下面的构造方法是吧异常交给方法调用者处理,主方法不知道如何处理这个异常然后把异常声明 * 抛出,将该异常交给JVM处理,JVM对异常的处理方式就是打印异常栈的跟踪信息,并终止程序运行 * 所以最后一句将不会被执行*/ Person person=new Person(500); System.out.println("我爱马文静"); /* 如果throw抛出的异常为Runtime异常则该语句或者方法无需放在try语句块中,也无需放在throws 声明抛出的方法里,也可以时用try catch 来捕获处理异常,也可以完全不理会该异常,把异常交给方法 的调用者处理 */ } }
关于自定义异常和throw的用法
最新推荐文章于 2024-04-14 00:02:15 发布