避免在Java中使用Checked Exception

Java的Exception分为两类,一类是RuntimeException及其子类,另外一类就是checked Exception。Java要求函数对没有被catch处理掉的checked Exception,需要将其写在函数的声明部分。然而,这一要求常常给程序员带来一些不必要的负担。

为了避免在函数声明中写throws部分,在Java项目里面常常可以看到以下代码用来‘吞掉’Exception:

这显然不是一个好的处理Exception办法,事实上,catch并处理一个Exception意味着让程序从发生的错误(Exception)中恢复过来。从这种意义上说,已上的代码只可能在一些很简单的情况下工作而不带来问题。

对于很多Exception,往往没有去处理它并让程序从错误中恢复出来的办法,这时唯一能做的事情可能就是在界面上显示一些提示信息给用户。这种情况下让程序抛出遇到的Exception是更为合理的做法。然而,这样做会使得一些函数的声明急剧膨胀。一个函数可能需要声明会抛出的7、8个checked Exception,而且每个调用它的函数也需要同样的声明。

比这更糟糕的是,这有可能破坏类设计的open-close原则。简单来说,open-close原则是指当扩展一个模块的时候,可以不影响其现有的client。open-close原则是通过继承来实现的,当继承一个类的时候,我们既扩展了这个类,也不会影响原有的client(因为对这个类没有改动)。

现在考虑下面这种情况,有一个父类Base:

现在需要继承Base这个类并重载foo这个方法,在新的实现中,foo可能抛出ExceptionB:

然而,这样写在Java里面是不合法的,因为Java把可能会抛出的Exception看作函数特征的一部分,子类声明抛出的Exception必须是父类的子集。

可以在Base类的foo方法中加入抛出ExceptionB的声明,然而,这样就破坏了open-close原则。而且,有时我们没有办法去修改父类,比如当重载一个Jdk里的类的时候。

另一个可能的做法是在Extend的foo方法中catch住ExceptionB,然后构造一个ExceptionA并抛出。这是个可行的办法但也只是一个权宜之计。

如果使用RuntimeException,这些问题都不会存在。这说明checked Exception并不是一个很实用的概念,也意味着在程序设计的时候,我们应该让自己的Exception类继承RuntimeException而不是Exception。(这和JDK的建议正好相反,实践证明这样做代码的质量更好。)

对于那些需要处理checked Exception的代码,可以利用一个ExceptionAdapter的类把checked Exception包装成一个RuntimeException抛出。ExceptionAdapter来自Bruce Eckel的Does Java need Checked Exception这篇文章,在这里的ExceptionAdapter是我根据JDK 1.4修改过的:

rethrow()的作用是把被包装的Exception再次抛出。

时间: 2024-08-12 23:16:13

避免在Java中使用Checked Exception的相关文章

java中catch (Exception e){.......}我们都知道Exception是一个类

问题描述 java中catch (Exception e){.......}我们都知道Exception是一个类 java中catch (Exception e){.......}我们都知道Exception是一个类,那e是Exception的一个子类还是Exception的一个对象呢,虽然有java中一切都是对象这种说法,那把e是子类还是对象呢 解决方案 唉 Exception是个类 那e不就是类对象 真是醉了 Exception 的子类都是各种错误 什么空指向异常等等 如果是子类 或者子类对

谈谈Java:Checked Exception与Runtime Exception 的区别

Java里有个很重要的特色是Exception ,也就是说允许程序产生例外状况.而在学Java 的时候,我们也只知道Exception 的写法,却未必真能了解不同种类的Exception 的区别.<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /> 首先,您应该知道的是Java 提供了两种Exception 的模式,一种是执行的时候所产生的Exception (Runtime

Java中异常Exception的实现的一些分析

文章地址:http://blog.csdn.net/hengyunabc/article/details/14108617 前言: 最近发现一个很有用的Eclipse插件:http://andrei.gmxhome.de/bytecode/,可以在Eclipse直接查看,调试Java的字节码. 顺带研究了下Java里异常的实现机制,还有JDK7里的mutil catch的实现原理. athrow指令: 在JVM里实现异常的指令是athrow,指令的参考在这里:http://docs.oracle

php中error与exception的区别及应用

  这篇文章主要介绍了php中error与exception的区别及应用,需要的朋友可以参考下 error与exception的区别查阅网上资料大多是java的解释,貌似php的异常处理过程与java差不多 java中的Object继承结构如下: Object---->Throwable--------> Exception ----> RuntimeException | Error Error都是unchecked类型 Exception分为checked 与 unchecked类型

Java中的异常和处理,你知道多少?

程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常.异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误给用户?或者用C语言风格:用函数返回值作为执行状态. Java提供了更加优秀的解决办法:异常处理机制. 异常处理机制能让程序在异常发生时,按照代码的预先设定的异常处理逻辑,针对性地处理异常,让程序尽最大可能恢复正常并继续执行,且保持代码的清晰. Java中的异常可以是函数中的语句执行时引发的,也可以是程序员通过throw 语句手动抛出的,只要在Java程序中

热闹背后的冷静思考:Kotlin 和 Checked Exception

最近 JetBrains 的 Kotlin 语言忽然成了热门话题.国内小编们传言说,Kotlin 取代了 Java,成为了 Android 的"钦定语言",很多人听了之后热血沸腾.初学者们也开始注意到 Kotlin,问出各种"傻问题",很"功利"的问题,比如"现在学 Kotlin 是不是太早了一点?" 结果引起一些 Kotlin 老鸟们的鄙视.当然也有人来信,请求我评价 Kotlin. 对于这种评价语言的请求,我一般都不予理睬

Java中的异常处理用法及其架构和使用建议_java

Java异常是Java提供的一种识别及响应错误的一致性机制. Java异常机制可以使程序中异常处理代码和正常业务代码分离,保证程序代码更加优雅,并提高程序健壮性.在有效使用异常的情况下,异常能清晰的回答what, where, why这3个问题:异常类型回答了"什么"被抛出,异常堆栈跟踪回答了"在哪"抛出,异常信息回答了"为什么"会抛出. Java异常机制用到的几个关键字:try.catch.finally.throw.throws. 关键字 说

php中error与exception的区别及应用_php技巧

error与exception的区别查阅网上资料大多是java的解释,貌似php的异常处理过程与java差不多 java中的Object继承结构如下: Object---->Throwable--------> Exception ----> RuntimeException | Error Error都是unchecked类型 Exception分为checked 与 unchecked类型 且把异常与错误都当作程序运行不正常的现象来看待 如果区分异常与错误的话:异常:非致命的.try

Java千百问_04异常处理(001)_什么是java中的异常

1.java异常是什么 java在执行期间产生了某些问题,导致执行中断,这一问题就称为异常. 不同的原因都可能产生异常,包括以下内容:==用户输入无效数据.==需要打开的文件不存在.==网络连接已丢失.==JVM已经耗尽内存.==将null当作某种对象进行操作. 2.异常都分为哪些 要了解在Java中如何异常处理工作,需要了解三类异常:检查异常(checked exception) 检查异常通常是用户错误,程序员并不可预见的问题.例如,如果一个文件被打开,但该文件无法找到,则会出现异常.这些异常