throws :声明抛出异常,在方法签名上.
throw :自行抛出异常,使用throw语句完成(throw后面没有s,切记、切记....)。
自行抛出异常的时候可以是throw语句,throw语句可以单独使用,throw语句抛出的不是异常类(throws抛出的是一个异常类),而是一个异常实例,而且每次只能抛出一个异常实例.throw 语句的语法格式为: throw ExceptionInstance .
自定义异常
用户自定义异常都应该继承Exception基类,如果希望自定义Runtime异常,应该继承RuntimeException基类. 定义异常类时,通常需要提供两种构造器:一种是无参数构造器;另一种是带一个字符串的构造器,这个字符串将作为该异常对象的详细说明.
下面例子创建了一个自定义的异常类.
@SuppressWarnings("serial") public class AuctionException extends Exception { //异常类无参数的构造器 public AuctionException() { super(); } //带一个字符串的构造器 public AuctionException(String message) { super(message); } }
上面例子中,带参数的构造器,同过super来调用父类的构造器.正是super的调用,可以将此字符串参数传递给异常对象的message属性,该message属性就是该异常对象的详细描述信息.
下面我们就来测试一下:
public class TestAuction { private double initPrice=30.0; public static void main(String[] args) { // TODO Auto-generated method stub TestAuction ta=new TestAuction(); try { ta.bid("0"); } catch (AuctionException e) { //main方法再次捕捉到bid方法的异常,并对该异常进行处理 System.out.println(e.getMessage()); } } public void bid (String bidPrice) throws AuctionException{ double d=0.0; try { d=Double.parseDouble(bidPrice); } catch (Exception e) { //此处可以完成本方法中可以对异常执行的修复处理,此处仅仅是在控制台打印异常跟踪棧信息 e.printStackTrace(); //再次抛出自定义异常 throw new AuctionException("竞拍价必须是数值,不能包含其它字符!"); } if(initPrice>d){ throw new AuctionException("惊怕价比起步价低,不允许竞拍!"); } } }
运行之后,在控制台就会打印出相应的异常信息.
异常处理的常用方式:
- 在出现异常的方法内,捕获并处理异常,该方法的调用者将不能再次捕获该异常.
- 该方法签名中声明抛出该异常,将该异常完全交给方法调用者来处理.
而在实际应用中:当一个异常出现时,单靠某个方法无法完全处理该异常,必须由几个方法协作才可完全处理该 异常.这时就可以通过在catch块中结合throw来完成. 上面例子就属于这种情形。