快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

避免在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再次抛出。





返回类别: 教程
上一教程: XML 和 Java:一个强盛的组合
下一教程: 各类Java资源收集(更新中……)

您可以阅读与"避免在Java中使用Checked Exception"相关的教程:
· 避免在Java中使用Checked Exception
· 在Struts中使用JavaBean和List(多行数据)类型属性
· JAVA中使用DIRECTDRAW
· 学习在JSP中使用JAVABEANS
· JAVA中使用JCOM操作OFFICE对象
    微笑服务 优质保证 索取样品