J2SE综合:JAVA异常处理方式的区别和分析

2016-02-19 20:24 4 1 收藏

今天给大家分享的是由图老师小编精心为您推荐的J2SE综合:JAVA异常处理方式的区别和分析,喜欢的朋友可以分享一下,也算是给小编一份支持,大家都不容易啊!

【 tulaoshi.com - 编程语言 】

一、内层方法抛出异常,外层方法捕捉并处理异常:
  
  public void methodA (){
     try{
         // 调用methodB
         methodB();
     }
     catch(ExceptionType et){
        // 相应处理措施
     }
  }
  
  public void methodB throws ExceptionType{
      if (condition is true)
      {
    // 相应处理措施
      }
   else
   {
    throw new ExceptionType(argument);
   }
  }
  
  在这个例子中,方法B的头部中声明了该方法会抛出一个类型为ExceptionType的异常,在方法体中使用throw子句抛出了一个异常,那么该异常被谁捕捉到呢,答案是方法A。因为异常抛出后,JVM会顺着该方法的调用栈一层一层的往上找。因为方法A中有一个catch(ExceptionType et),所以被抛出的异常会被捕捉到并处理。
  
  
  二、方法中自己捕捉,处理异常:
  
  public methodA() {
   try
   {
    // 可能产生异常的语句
   }
   catch (ExceptionType et)
   {
    // 相应的处理
   }
  }
  在这个例子中,方法A使用了try-catch语句块,那么意味着在方法中所产生的ExceptionType类型的异常都会被捕捉到并在方法内处理。
  
  
  三、内层方法抛出一个异常,但本身又有try-catch
  
  public methodB() throws ExceptionType{
   
   try
   {
    // 可能产生异常的语句
   }
   catch (AnotherExceptionType aet)
   {
    // 相应处理措施
   }
  }
  在这个例子中有两种异常处理情况,抛出异常和捕捉异常,如果在try语句块中产生ExceptionType类型的异常的话,会被抛出。如果产生AnotherExceptionType类型的话,则不会被抛出,因为在方法B的头部中并没有声明会抛出该异常。
  
  
  四、内层方法抛出一个异常,但本身有try-finally
  
  public methodB() throws ExceptionType{
  
   try
   {
    // 可能产生异常的语句
   }
   finally
   {
    // 一定要执行的语句
   }
  }
  这个例子与上一个例子很像,不同的是没有catch,但增加了finally。它的意思如果方法B中try语句块中如果产生了异常,则抛出由外层方法处理。然后方法B继续执行finally中的语句
  
  
  下面列举三种错误的异常处理方法:
  
  一、内层方法抛出一个异常,但本身有捕捉这个异常
  
  public methodB() throws ExceptionType{
   
   try
   {
    // 可能产生异常的语句
   }
   catch (ExceptionType et)
   {
    // 相应处理措施
   }
  }
  在这个例子中,方法B在头部声明了会抛出一个类型为ExceptionType的异常,但在紧接下来的方法体又用了catch(ExceptionType et),如果产生了异常的话,会有什么结果呢?方法B抛出的异常马上被自身的catch捕捉到,所以方法头部的throws实际是没有作用的。外层方法是接收不到方法B抛出的异常对象的。
  
  
  二、在try中使用了return,在fianlly中又使用了return 
  
  public methodB() {
  
   try
   {
    // 可能产生异常的语句
    return SOMEVALUE;
   }
   catch ()
   {
   }
   finally
   {
    return SOMEVALUE_2;
   }
  
  }
  在这个例证中,我们可以看到在try中返回了SOMEVALUE,那么程序执行到这里是否就结束了呢,其实不是的,因为finally中的语句是肯定会被执行到的,所以最后返回的是SOMEVALUE_2;那么意味者即使程序没有抛出异常,最后也得不到正确的结果。
  
  
  三、把catch(Exception e)放在所有catch块的最前面
  public methodB(){
   try
   {
    
   }
   catch (Exception e)
   {
    ...
   }
   catch (SubException se)
   {
    ...
   }
  
  }
  在这个例子中,catch(Exception e)被放在所有catch语句块的最前面,因为Exception所有Exception类型的父类,所以意味着所有在try中产生的异常都会被捕捉到。后面其他的catch都是没有用的,所以一定要把catch(Exception e)放在最后面,如果前面所有的异常类型都不符合,至少保证还有一个可以处理它。
  
   
  
  总结:
  A.如果能够找到一个有意义的方法来捕获异常,就立即引入这个方法
  B.否则就应该考虑做某些处理后传递或者再次抛出异常,也可以把异常转换为另一种形式,然后抛出一个新的异常
  C.另一个方法是,可以完全忽略这个异常,而把它加到方法的头部的throws语句中,由调用这个方法的方法来处理它
  D.通过捕获一个公共的异常超类,可以在一个块里面捕获多个异常,但不能够用一个空的catch语句 块来完全制止一个异常。

来源:http://www.tulaoshi.com/n/20160219/1623559.html

延伸阅读
标签: Java JAVA基础
要保存的也被保存了下来。一般情况下,我们仅仅需要保存逻辑数据就可以了。不需要保存的数据我们可以用关键字transient标出。 以下是一个例子: import java.io.*; public class Serial implements Serializable { int company_id; String company_addr; transient boolean company_flag; ...
J2SE 5.0引入了许多新型的集合API-你需要了解它们以便能够正确地实现泛型定制的集合-它可以无缝地与多种类型和新型的"for each"结构一起工作。本文将向你展示示怎样创建与J2SE最新特征相兼容的集合。 一、 创建支持泛型的类 !-- frame contents -- !-- /frame contents -- 首先,你必须学习如何创建一个答...
  对国际化和本地化的支持是Java 标准版一个优点。 Java SE 6 一如既往地为那些注重本地化资源访问和操作的应用程序开发者提供支持。Java SE 6在以下几方面为本地化作了加强: .资源的访问和控制 .针对本地化的服务   .归一化文本   .国际域名  .日本国的日历   .新增locales &nbs...
标签: Java JAVA基础
当一个父类实现Serializable接口后,他的子类都将自动的实现序列化。 以下验证了这一点: package Serial; import java.io.Serializable; public class SuperC implements Serializable {//父类实现了序列化 int supervalue; public SuperC(int supervalue) { this.supervalue = supervalu...
首先要了解Java默认的序列化行为,java将一切关于对象的信息都保存了下了,也就是说,有些时候那些不需要保存的也被保存了下来。一般情况下,我们仅仅需要保存逻辑数据就可以了。不需要保存的数据我们可以用要害字transient标出。 以下是一个例子: import java.io.*; public class Serial implements Seria...

经验教程

319

收藏

88
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部