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

unchecked异常

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

辩论似乎结束了。 在这篇文章中,我将尝试包含涉及该主题的文章和书籍的链接。 我不是专家,但是我会尽力向您解释为什么我得出这个结论。

所以,我们正在谈论,

未检查的异常:
  • 表示程序中的缺陷(错误)–通常将无效参数传递给非私有方法。 引用Gosling,Arnold和Holmes的《 Java编程语言》:“未经检查的运行时异常表示的条件通常可以反映程序逻辑中的错误,并且无法在运行时合理地恢复。”
  • 是RuntimeException的子类,通常使用IllegalArgumentException,NullPointerException或IllegalStateException实现
  • 一个方法没有义务为由其实现引发的未经检查的异常建立策略(并且它们几乎总是不这样做)
检查异常:
  • 表示程序无法直接控制的区域中的无效条件(无效的用户输入,数据库问题,网络中断,文件缺失)
  • 是Exception的子类
  • 一个方法必须为由其实现抛出的所有检查的异常建立一个策略(将检查的异常进一步传递到堆栈中,或以某种方式进行处理)
以上是Java实践页面[ 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合作伙伴会 在Java中使用Unchecked异常而不是Java Checked异常   面向对象的生活博客中的Manu PK。


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

unchecked异常

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/357486.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微型计算机系统中的内部寄存,微机原理与接口技术习题集汇总.doc

微机原理与接口技术习题集汇总.doc (50页)本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦!29.9 积分.word格式,第二章 微机基本组成及工作原理1.1微型机的基本结构一、单项选择题1&#xf…

10个对Web开发者最有用的Python包

Python最近成为了开发人员最喜欢的语言之一。无论你是专业的,业余的,还是一个初学者,你都可以从Python语言及其程序包中受益。Python已经被证明是当今最具活力的面向对象的编程语言之一。这就是为什么即使是世界顶级公司也广泛使用这种语言的…

移动端适配的几种解决办法

所谓移动端适配,就是WebApp在不同尺寸的屏幕上等比显示 原则 开发时方便,写代码时设置的值要和标注的 160px 相关方案要适配大多数手机屏幕,并且无 BUG用户体验要好,页面看着没有不适感思路 写页面时,按照设计稿写固定宽度,最后再统一缩放处理,在不同手机上都能用按照设…

真正释放Maven和Java EE的强大功能

如果野心和愿景太复杂而无法使用,那么它们可能会毁灭伟大的解决方案。 尽管Maven和Java EE是在整个Java行业中都已建立的良好技术,但是使用它们并使用其作者希望您使用的所有技术和模式来设计项目可能非常棘手。 在开发过程中途,由于一开始就…

浙江丽水学院计算机专业,2019丽水学院专业排名

丽水学院是一所公办全日制普通本科高校,地处浙江绿谷、瓯江之畔、国家级生态示范区——丽水市。为了让大家更好的了解这所大学的专业排名,下面是学习啦小编给大家带来的丽水学院专业排名,供大家参考!丽水学院王牌专业名单省级重点专业&#x…

开发高性能JAVA应用程序基础(内存篇)

虽然JAVA的垃圾回收和当前高配置的服务器可以让程序员大部分时间忘掉OutOfMemoryError的存在,但是访问量增大后频繁的GC会额外消耗CPU (使用top查看结果为us值高),系统响应速度下降,积压的请求又会占用更多内存从而恶性循环,严重时…

【前端面试题】2021/3/12挺经典的面试题,这个经历很深刻。

今天面试去啦,填了职业性格测试,人格测试及招聘的基本经历信息,面试官是技术头头,柔中带钢,问题润物细无声的感觉,很考验基本功。 上午10:30面试了一个达达的前端,采用的是线上腾讯会议的方式&a…

html5 ios cookie,ios – WKWebView,获取所有cookie

我想从WKWebView获取所有cookie.为什么?我已经启动了一个使用基于Web的身份验证的项目.因此,我应该拦截cookie以确保用户已登录并用于其他目的.另一种情况 – 想象一下,如果用户登录,而不是“杀死”应用程序 – 由于存储此cookie会话的一些延迟将丢失:(.The problem…

【前端面试题】2021/3/15面试题

最近在boss直聘上投了很多简历,记录一下今天的面试题,这个好几个都是电话直接打过来问时间方便?我一回答方便就直接开始丢题目,我也不知道哪个公司的。感觉公司不是很正规的感觉,感觉那边有个问题题库,面试…

计算机考研数学基础知识点,2019计算机考研数学复习:打好基础是必须的啊喂!...

"基础不牢,地动山摇"这句话形容考研数学的复习真是太贴切不过了,尤其是对处于打基础阶段的19考研党们来说,新东方在线整理了2019计算机考研数学复习:打好基础是必须的啊喂!很多同学都存在着这样的误区:考研数…

javafx打包路径问题_关于JavaFX的最常见问题

javafx打包路径问题上周,我在斯德哥尔摩的Jfokus 2012上做了一个关于JavaFX的演讲,当时我意识到每次活动都会问三个问题。 似乎有一个普遍的兴趣,所以我尝试在这篇文章中回答他们(尽可能的说实话): iPad或其…

【前端面试题】关于一些js的一些面试题(金融行业),我和面试官扯了三个小时

今天去面试了一家金融公司,招聘比较着急,一面后直接二面等结果,这种公司一般对js要求比较高,笔试题基本都是js相关的题,针对公司的客户要求也会做一些jquery,vue.react相关的插件,H5及webAPP。下面直接说题…

操作系统下查看HBA卡信息wwn的方法

一、Windows 系统在Windows系统中,可以使用FC HBA卡厂家提供的管理软件查看光纤适配器的WWN号码,具体如下:Qlogic:SANsurferEmulex:HBAnywarehttp://www.microsoft.com/en-us/download/details.aspx?id17530安装以后使…

上海大学计算机学院客座教授,刘云虹教授受聘上海大学外国语学院客座教授并做学术讲座...

11月29日14:00,南京大学外国语学院副院长、博士生导师刘云虹教授被我院聘为客座教授并做主题为《中国文学外译与翻译历史观》的学术讲座。学院副院长苗福光教授主持,副院长邓志勇教授(主持工作)为刘教授颁发了聘书。讲座从刘教授自己的学术研究领域和起点…

使用RxJava和SseEmitter进行服务器发送的事件

Spring Framework 4.2 GA即将发布,让我们看一下它提供的一些新功能。 引起我注意的一个事件是一个简单的新类SseEmitter ,它是对Spring MVC控制器中易于使用的发送事件的抽象。 SSE是一项技术,使您可以在一个HTTP连接内沿一个方向将数据从服务…

常用正则表达式整理【总结】

平时不太喜欢记忆这些东西,开发的时候需要拿过来直接用就好,还有面试的时候直接让你敲的,这里记录一下。 目录 一、校验数字的表达式 二、校验字符的表达式

cmstop中实例化controller_admin_content类传递$this,其构造方法中接收到的是--名为cmstop的参数--包含cmstop中所有属性...

主程序cmstop类,实例化controller_admin_content类(接收请求后拼接的).传递cmstop所有属性过去.controller_admin_content.构造方法中接收到名称为cmstop,已经内容为cmstop所有属性 class cmstop extends object{public $app, $controller, $action, $args, $class } 设置好属性…

XPS 15 9530使用Windows10频繁发生Intel HD Graphics 4600驱动奔溃的一种解决方法

本人使用XPS 15 9530、集成显卡为Intel HD Graphics 4600、操作系统Windows 10 Pro,使用过程当中经常会发生集成显卡奔溃的问题,错误提示如下: Display driver stopped responding and has recovered Display driver Intel HD Graphics Drive…

安徽阜阳计算机高中学校排名,安徽阜阳排名靠前的三大高中,有争议?2020年高考成绩说话!...

安徽省阜阳市,古称汝阴,阜阳历史悠久、文化璀璨、人才辈出,有阜阳剪纸等国家非物质文化遗产,也是管仲、鲍叔牙等历史名人的故乡;阜阳风景秀丽,辖区内有诸多知名景点,其中八里河风景区为国家AAAA…