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来完成. 上面例子就属于这种情形。