`
yk.yk
  • 浏览: 20105 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

RuntimeException与CheckedException差异

阅读更多
Java提供了两类主要的异常:runtime exception和checked exception。所有的checked exception是从java.lang.Exception类衍生出来的,而runtime exception则是从java.lang.RuntimeException或java.lang.Error类衍生出来的。

  它们的不同之处表现在两方面:机制上和逻辑上。
  一、机制上

  它们在机制上的不同表现在两点:1.如何定义方法;2. 如何处理抛出的异常。请看下面CheckedException的定义:

  public class CheckedException extends Exception
  {

  public CheckedException() {}
  public CheckedException( String message )
  {
  super( message );
  }
  }

  以及一个使用exception的例子:

  public class ExceptionalClass
  {

  public void method1()
  throws CheckedException
  {
   // ... throw new CheckedException( “...出错了“ );
  }
  public void method2( String arg )
  {
   if( arg == null )
   {
    throw new NullPointerException( “method2的参数arg是null!” );
   }
  }
  public void method3() throws CheckedException
  {
   method1();
  }
  }

  你可能已经注意到了,两个方法method1()和method2()都会抛出exception,可是只有method1()做了声明。另外,method3()本身并不会抛出exception,可是它却声明会抛出CheckedException。在向你解释之前,让我们先来看看这个类的main()方法:

  public static void main( String[] args )
  {

  ExceptionalClass example = new ExceptionalClass();
  try
  {
  example.method1();
  example.method3();
  }
  catch( CheckedException ex ) { } example.method2( null );
  }

  在main()方法中,如果要调用method1(),你必须把这个调用放在try/catch程序块当中,因为它会抛出Checked exception。

  相比之下,当你调用method2()时,则不需要把它放在try/catch程序块当中,因为它会抛出的exception不是checked exception,而是runtime exception。会抛出runtime exception的方法在定义时不必声明它会抛出exception。

  现在,让我们再来看看method3()。它调用了method1()却没有把这个调用放在try/catch程序块当中。它是通过声明它会抛出method1()会抛出的exception来避免这样做的。它没有捕获这个exception,而是把它传递下去。实际上main()方法也可以这样做,通过声明它会抛出Checked exception来避免使用try/catch程序块(当然我们反对这种做法)。

  小结一下:

  * Runtime exceptions:

  在定义方法时不需要声明会抛出runtime exception;

  在调用这个方法时不需要捕获这个runtime exception;

  runtime exception是从java.lang.RuntimeException或java.lang.Error类衍生出来的。

  * Checked exceptions:

  定义方法时必须声明所有可能会抛出的checked exception;

  在调用这个方法时,必须捕获它的checked exception,不然就得把它的exception传递下去;

  checked exception是从java.lang.Exception类衍生出来的。

  二、逻辑上

  从逻辑的角度来说,checked exceptions和runtime exception是有不同的使用目的的。checked exception用来指示一种调用方能够直接处理的异常情况。而runtime exception则用来指示一种调用方本身无法处理或恢复的程序错误。

  checked exception迫使你捕获它并处理这种异常情况。以java.net.URL类的构建器(constructor)为例,它的每一个构建器都会抛出MalformedURLException。MalformedURLException就是一种checked exception。设想一下,你有一个简单的程序,用来提示用户输入一个URL,然后通过这个URL去下载一个网页。如果用户输入的URL有错误,构建器就会抛出一个exception。既然这个exception是checked exception,你的程序就可以捕获它并正确处理:比如说提示用户重新输入。

  再看下面这个例子:

  public void method()
  {

  int [] numbers = { 1, 2, 3 };
  int sum = numbers[0] numbers[3];
  }

  在运行方法method()时会遇到ArrayIndexOutOfBoundsException(因为数组numbers的成员是从0到2)。对于这个异常,调用方无法处理/纠正。这个方法method()和上面的method2()一样,都是runtime exception的情形。上面我已经提到,runtime exception用来指示一种调用方本身无法处理/恢复的程序错误。而程序错误通常是无法在运行过程中处理的,必须改正程序代码。

  总而言之,在程序的运行过程中一个checked exception被抛出的时候,只有能够适当处理这个异常的调用方才应该用try/catch来捕获它。而对于runtime exception,则不应当在程序中捕获它。如果你要捕获它的话,你就会冒这样一个风险:程序代码的错误(bug)被掩盖在运行当中无法被察觉。因为在程序测试过程中,系统打印出来的调用堆栈路径(StackTrace)往往使你更快找到并修改代码中的错误。有些程序员建议捕获runtime exception并纪录在log中,我反对这样做。这样做的坏处是你必须通过浏览log来找出问题,而用来测试程序的测试系统(比如Unit Test)却无法直接捕获问题并报告出来。

  在程序中捕获runtime exception还会带来更多的问题:要捕获哪些runtime exception?什么时候捕获?runtime exception是不需要声明的,你怎样知道有没有runtime exception要捕获?你想看到在程序中每一次调用方法时,都使用try/catch程序块吗?
分享到:
评论

相关推荐

    Java语言中的两种异常

    在Java中,`CheckedException`和`RuntimeException`在方法定义与异常声明上的差异显著。`CheckedException`要求任何可能抛出此类异常的方法都必须在其方法签名中明确声明,这意味着调用者在编译时就能知道该方法可能...

    JAVA程序员面试宝典

    - **异常分类**:异常分为运行时异常(RuntimeException)和检查型异常(Checked Exception)。运行时异常通常发生在程序执行期间,由于编程错误或者环境条件导致,如数组越界、空指针异常等。检查型异常则是编译器...

    java面试题!!!!!!!!!!!!!

    - 一般异常(Checked Exception)是预期之外但可处理的异常,Java编译器强制要求处理或声明抛出。 5. **Servlet生命周期与CGI的区别** - Servlet生命周期包括`init()`、`service()`和`destroy()`方法。 - ...

    Java面试笔试题集锦

    Java中的异常主要分为两大类:`RuntimeException`和`Checked Exception`。`RuntimeException`通常是由编程错误导致的,比如空指针异常(`NullPointerException`)、数组越界异常(`ArrayIndexOutOfBoundsException`)等...

    php中error与exception的区别及应用

    Checked异常是编译时需要处理的异常,通常与外部资源的交互(如文件I/O或网络连接)相关。而Unchecked异常,包括RuntimeException及其子类,是运行时异常,通常表示程序逻辑错误。PHP的异常处理方式与Java类似,但...

    华南资讯笔试java 2013

    此外,考生应熟悉常见的异常类型及其区别,如运行时异常(RuntimeException)和检查性异常(Checked Exception)。 ### 4. String操作 字符串是Java中最常用的数据类型之一。笔试可能会要求考生掌握String类的方法...

    java面试题

    Java中的异常分为两大类:运行时异常(RuntimeException)和非运行时异常(checked exception)。运行时异常通常是程序错误导致的,一般不需要显示捕获;而非运行时异常通常由外部条件引起,必须被捕获或者在方法...

    Java笔试题Java笔试题

    Java中的异常处理机制包括检查性异常(Checked Exception)和运行时异常(RuntimeException)。检查性异常必须被捕获或声明抛出,而运行时异常则可以在不被捕获的情况下抛出。合理地使用异常处理可以增强程序的健壮...

    java面试题集合

    异常分为受检异常(Checked Exception)和非受检异常(Unchecked Exception)。受检异常需要在编译时显式处理或者声明抛出;非受检异常包括运行时异常(RuntimeException)和错误,它们在编译时不需要特别处理。 ##...

    大唐JAVA笔试题

    Java中的异常机制及CheckedException与UncheckedException - **异常处理机制**: - Java通过异常处理机制来处理程序中的错误,包括抛出异常、捕获异常和处理异常。 - **CheckedException**: - 需要在方法签名中...

    SimpleJava.pdf

    - **异常分类**:运行时异常(RuntimeException)与检查异常(Checked Exception)。 - **异常继承**:所有异常都是Throwable类的子类。 - **自定义异常**:扩展Exception类或RuntimeException类创建自定义异常。 #...

    JAVA相关基础知识的面试题.docx

    - **定义**:运行时异常(RuntimeException)是在程序运行时可能会发生的异常,而一般异常(Checked Exception)是指那些需要显式处理的异常。 - **区别**: - **捕获要求**:运行时异常不需要强制捕获,而一般异常...

    JAVA问题集

    - `Unchecked Exception`主要是指`RuntimeException`及其子类,这类异常不需要在编译时显式处理。 - 使用`try-catch`块可以捕获并处理异常,对于未捕获的异常,程序可以通过定义全局异常处理器等方式进行统一管理...

    JAVA 面试题集 pdf

    - `Exception`又分为`RuntimeException`和非`RuntimeException`。 5. **最佳实践:** - 对于可预见的异常应该捕获并处理。 - 不应捕获`Throwable`类及其父类的异常,除非确实需要记录所有类型的错误。 - 尽量...

    SCJP必掌握的英语词汇

    在编程中,这可能指不同编程语言之间的细微差异或实现特定功能的不同方式。 #### 具体的类 (Concrete Class) **具体的类**是指非抽象类,即具有具体实现的类。在面向对象编程中,具体的类可以实例化为对象。 ####...

Global site tag (gtag.js) - Google Analytics