自定义异常

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

   


 

原文地址:https://www.cnblogs.com/wuyida/p/6300444.html