(一)printsrtackTrace()方法,用来跟踪异常事件发生时执行堆栈的内容
下面看无printsrtackTrace()的java代码:
class myException extends Exception{
private int id;
public myException(String message,int id){
super(message);
this.id=id;
}
public int getid(){return id;}
}
public class Test2 {
public void regist(int num)throws myException{
if(num<0){
throw new myException("登记人数为负,不合理",3);
}
System.out.println("登记人数"+num);
}
public void manager(){
try{regist(-5);}
catch(myException e){
System.out .println("登记失败,出错类型码="+e.getid());
}
System.out.println("操作结束");
}
public static void main(String[] args){
Test2 t = new Test2();
t.manager();
}
}
运行结果:
登陆失败,出错类型码=3
操作结束
对以上代码进行分析:首先自定义了一个myException继承父类异常Exception(父类引用指向子类对象),然后看main方法,main方法中new了一个Test为t,然后执行t.manager,即执行manager方法,在manager中捕获代码段regist(-3)的异常,由于regist方法有异常,,往下执行catch语句,打印出来“登陆失败,出错类型码=3”,由于没有使用printsrtackTrace()语句,则追踪不到异常发生时代码执行时的内容,则执行完catch后代码继续往下执行,则打印出来“操作结束”。
下面看有printsrtackTrace()的java代码:
class myException extends Exception{
private int id;
public myException(String message,int id){
super(message);
this.id=id;
}
public int getid(){return id;}
}
public class Test2 {
public void regist(int num)throws myException{
if(num<0){
throw new myException("登记人数为负,不合理",3);
}
System.out.println("登记人数"+num);
}
public void manager(){
try{regist(-5);}
catch(myException e){
System.out .println("登记失败,出错类型码="+e.getid());
e.printStackTrace();
}
System.out.println("操作结束");
}
public static void main(String[] args){
Test2 t = new Test2();
t.manager();
}
}
运行结果:
登陆失败,出错类型码=3
cast03.myException: 人数为负值,不合理
at cast03.Test2.regist(Test2.java:20)
at cast03.Test2.manager(Test2.java:25)
at cast03.Test2.main(Test2.java:34)
操作结束
分析上述代码,当代码执行到System.out .println("登陆失败,出错类型码="+e.getid());后打印出来“登陆失败,出错类型码=3”,接着e.printStackTrace()追踪异常发生时执行堆栈的内容,即打印“人数为负,不合理”,紧接着代码继续往下执行System.out .println("操作结束");打印“操作结束”。
(二)自定义异常
使用自定义异常的一般有如下步骤:
《1》通过继承java.lang.Exception类声明自己的异常类;
《2》在方法适当的位置生成自定义异常的实例,并用throw语句抛出;
《3》在方法的声明部分用throws语句声明该方法可能抛出的异常。