关于检查与未检查的异常的争论可以追溯到过去。 有人说这是Java包含的最佳功能之一。 其他人则说这是他们最大的错误之一[ 1 ]。


辩论似乎结束了。 在这篇文章中,我将尝试包含指向该主题的文章和书籍的链接。 我不是专家,但是我会尽力向您解释为什么我得出这个结论。
所以,我们正在谈论,
未经检查的异常:
  • 表示程序中的缺陷(错误)–通常将无效参数传递给非私有方法。 引用Gosling,Arnold和Holmes的《 Java编程语言》:“未经检查的运行时异常表示的条件通常可以反映程序逻辑中的错误,并且无法在运行时合理地恢复。”
  • 是RuntimeException的子类,通常使用IllegalArgumentException,NullPointerException或IllegalStateException实现
  • 一个方法没有义务为由其实现引发的未经检查的异常建立策略(并且它们几乎总是不这样做)
检查异常:
  • 表示程序无法直接控制的区域中的无效条件(无效的用户输入,数据库问题,网络中断,文件缺失)
  • 是Exception的子类
  • 一个方法必须为由其实现抛出的所有检查的异常建立一个策略(将检查的异常进一步传递到堆栈中,或以某种方式进行处理)
上面是在Java Practices Page [ 2 ]中讲述的。
在我从事的许多项目中,我看到了不同的编码方式以及各种不同的策略,代码格式,类命名样式,数据库和技术。 保持不变的一件事是例外。 所有项目都有自定义异常,这些异常是通过扩展Exception类而创建的!
我敢肯定,我们大多数人都知道检查和未检查异常之间的区别,但是很少有人在使用它们之前会仔细考虑。 我希望所有详细信息都在单个页面中列出,以便说服我的团队切换到“未经检查的异常”。
罗伯特·C·马丁(Robert C. Martin)在他着名的《 干净的代码:敏捷软件技巧手册》 [ 3 ]中写下了以下几行,以支持未检查的异常。
辩论结束了。 多年来,Java程序员一直在争论 检查异常 的好处和责任 Java 的第一个版本中引入检查异常时 ,它们似乎是一个好主意。 每个方法的签名将列出 它可以传递给调用方的 所有 异常。 而且,这些异常是该类型的一部分
该方法。 如果签名与您的 代码 不匹配,则您的 代码 将无法编译

当时,我们认为检查异常是个好主意; 是的,它们可以 带来一些好处。 但是,现在很明显,对于 强大的软件来说 ,它们不是必需的 C#没有检查异常,尽管尝试了各种英勇的尝试,C ++ 也没有。 Python或Ruby都没有。 但是有可能用所有 这些语言 编写健壮的软件 因为是这种情况,所以我们必须(真的)决定是否应该检查 异常。

如果您正在编写关键库,则检查异常有时会很有用:您 必须捕获它们。 但是在一般应用程序开发中,依赖项成本大于 收益

最后一行是最重要的,他谈到了一般的应用程序开发,让我们举个例子,
如果必须使用DOM解析器读取XML文件,则需要处理一些经过检查的异常[ 5 ],例如ParserConfigurationException,SAXException和IOException。 API开发人员认为,如果XML无效,则应通知他们,以便API的使用者(即应用程序开发人员)可以决定如何处理这种情况。
现在,如果您有其他选择来进行常规逻辑操作,则可以这样做,否则,应该捕获这些已检查的异常并抛出和未检查的异常。 这样,方法签名也将很干净,我们指出如果XML无效,我们将无法做很多事情,并且我们将停止处理。 让写在顶层的错误处理程序对做什么做出适当的决定。
因此,我们需要做的就是通过扩展RuntimeException来创建自定义异常类。
在Oracle托管的Java教程中,有一个关于该辩论的有趣页面[ 4 ],该页面以该行结尾。 如果可以合理地期望客户端从异常中恢复,请将其设置为已检查的异常。 如果客户端无法采取任何措施来从异常中恢复,请将其设置为未经检查的异常。

我也发现很少文章支持这一点,

霍华德·刘易斯·希普的检查异常的悲剧
杰德·卫斯理·史密斯(Jed Wesley-Smith) 是个例外
例外检查我爱你,但你得走了 Misko Hevery

另外,很少有文章介绍一般的最佳最佳实践,

Vineet Reynolds 处理异常的准则
异常处理反模式作者:Tim McCune
杰出实践,作者Brian Goetz 异常处理的最佳实践作者:Gunjan Doshi

参考: 为什么我们的JCG合作伙伴 会使用Unchecked异常而不是Java中的Checked异常   面向对象的生活博客中的Manu PK。

翻译自: https://www.javacodegeeks.com/2012/03/why-should-you-use-unchecked-exceptions.html

为什么要在Java中使用Unchecked异常而不是Checked异常相关推荐

  1. unchecked异常_为什么要在Java中使用Unchecked异常而不是Checked异常

    unchecked异常 关于检查与未检查的异常的争论可以追溯到过去. 有人说这是Java包含的最佳功能之一. 其他人则说这是他们最大的错误之一[ 1 ]. 辩论似乎结束了. 在这篇文章中,我将尝试包含 ...

  2. java 异常 不抛,java中不捕获或抛出的异常

    java中不捕获或抛出的异常 发布时间:2020-06-25 14:29:16 来源:亿速云 阅读:137 作者:Leah 这期内容当中小编将会给大家带来有关java中不捕获或抛出的异常,文章内容丰富 ...

  3. java中int和integer的区别_Java异常中throw和throws关键字的区别

    Java中常常弄混的两个关键字,throw和throws,它们有什么区别呢?如何记忆他们,而不至于出错呢? throw和throws 区别 throws:出现在方法的签名中,声明当前方法可能抛出的所有 ...

  4. 五、Java中常用的API(通过包进行分类)————异常、多线程和Lambda表达式

    之前已经介绍了java.lang包下的相关类,今天将要补充两个常用的API:java.lang.Throwable和java.lang.Thread 一.异常(java.lang.Throwable) ...

  5. Java中常见的50个错误、异常及规避技巧

    阐述:在java的开发生涯中,我们总会遇到这样子那样子的异常,有时候花费一天的精力都解决不了,所以总结异常尤为变得重要,也是学习的一种积累经验.下面是我看到别的文章总结的,摘抄出来供打架分享. 编译器 ...

  6. Java中switch参数传null会引起异常——Java 语法糖

    问题 switch 参数不能是null,swicth(null)会报java.lang.NullPointerException异常 查找原因 为什么会这样呢,查找一下原因: 找到编译后的class文 ...

  7. java 如何捕获线程中的异常处理_如何捕获Java中另一个线程抛出的异常?

    参见英文答案 > How to catch an Exception from a thread                                    14个 我正在使用一个创建 ...

  8. 了解Java中的检查与未检查异常

    约书亚·布洛赫(Joshua Bloch)在< 有效的Java >中说 将检查的异常用于可恢复的条件,将运行时异常用于编程错误(第二版中的项目58) 让我们看看我是否正确理解了这一点. 这 ...

  9. java中的异常种类和区别以及处理机制和区别

    java中的异常种类和区别以及处理机制和区别 按照异常需要处理的时机分为编译时异常(也叫强制性异常)也叫 CheckedException 和运行时异常(也叫非强制性异常)也叫 RuntimeExce ...

最新文章

  1. 上周回顾:微软与苹果比赛谁更“不安全”
  2. js函数 every some map ()=a+b;
  3. 写给程序员的美术创作指南
  4. C语言实现缓冲区溢出实例
  5. 互联网公司们眼中的最强quot;世界杯阵容quot;
  6. linux定时器时间间隔为0,linux下定时器的使用--timer_create等系列
  7. 在SQL Server 2000中使用Transact-SQL建立数据库
  8. Java并发——Synchronized关键字和锁升级,详细分析偏向锁和轻量级锁的升级
  9. 游戏和数学笔记—常拿起来看看
  10. maven安装配置换阿里源
  11. 图书租赁管理系统——数据流程图
  12. Cartoon Animator动画制作软件CTA自动保存项目小工具
  13. 游戏王,查卡器,编号,开源,代码,OCG,程序
  14. Spring Boot 注解原理,自动装配原理,图文并茂,万字长文!
  15. html数据复制粘贴,如何复制和粘贴 HTML (HTML)
  16. Grid-Based Route (Re-)Planning
  17. c语言中的下标变量是什么,c语言中数组的下标从什么开始?
  18. 【好工具】在线免费无限制的PDF处理工具(转换、编辑、分割、合并、压缩)...
  19. 从逐笔成交分析主力异动
  20. 传感器 | 基于新型的MEMS气体微密度计的密度和浓度测量应用

热门文章

  1. spring jpa 流式_从响应式Spring Data存储库流式传输实时更新
  2. java设计模式 订阅模式_Java中的复合设计模式
  3. react 线程_React式服务中的线程本地状态可用性
  4. dc/os_DC / OS中具有Java和数据库应用程序的服务发现
  5. 动态代码生成 静态代码生成_将速度提升到自己的个人代码生成器中
  6. eclipse扩展点_Eclipse扩展点评估变得容易
  7. Vaadin 10+作为CUBA UI的未来
  8. Java序列化魔术方法及其示例使用
  9. 在Gradle中为JPMS构建Java 6-8库
  10. 使用SparkJava和Graal的本机微服务