什么时候应该选择检查异常/非检查异常?

2024-01-11

我从各种教程中了解到“如果可以合理地期望客户端从异常中恢复,则将其设置为受检查的异常。如果客户端无法执行任何操作来从异常中恢复,则将其设置为未检查的异常。”

我很想通过一些代码示例来看看前面的语句的有效性。 例如

try {
        br.readLine();
    } catch (IOException e) {

        e.printStackTrace();
    }

这里,IOException是检查异常。那么,当这个异常发生时我应该如何恢复呢?在这里,我排除了异常日志记录、异常重新抛出任务,因为它们实际上并未恢复,即使事情正确。那么,这里应该应用什么修改来恢复呢?

如果有办法从中恢复,那么可以将相同的方法应用于以下代码:

 try{
    Integer.parseInt("ghg4");
 }catch(NumberFormatException nfe){   
   }

这里 NumberFormatException 是一个运行时/未经检查的异常。因此,如果有办法从中恢复,那么为什么首先将其声明为运行时异常呢?


我看到三种类型的异常。一种极端是您无能为力的异常,例如 NullPointerException。您将在代码中以非常高的级别处理这个问题,或者根本不处理。如果去检查的话那就太可笑了。

另一端是提供有意义信息的。它们是一种返回值的方式,有时是复杂的,当方法已经有返回值时。它们也是跳转调用堆栈的简单方法。 (我可以写一本关于这个的书,但我就到此为止。) EOFExceptionought就是一个很好的例子。文件有其结尾,您迟早会遇到它,并且您不想每次读取时都检查它。在这种情况下,需要检查异常。 (我认为 user1291492 会同意我的观点。)这种情况有可能发生,任何调用 read 方法的人都应该为此做好准备。他们更喜欢编译器错误而不是运行时错误。

Now,除了这种类型的例外,您do not想要放入堆栈跟踪!这要花费很多时间。调用者只需要知道他击中了 EOF,而不是它发生在 IO 系统深处的哪个位置!此外,除非有有趣的信息要返回,否则异常本身应该是final static引用,生成一次并用于发生的每个 EOF。

中间的第三种类型是 Java 库使用的类型,例如realEOF异常。他们没有任何意义。要么调用者期望永远不会得到 EOF(例如,他将自己的标记放在那里),并且 EOFException 与 NullPointerException 具有相同的性质,or他期望它,并且不需要堆栈跟踪的麻烦和损失的处理时间。我认为问题在于 Java 设计者本身(我必须​​承认,当我想到这个问题时,我自己也遇到过这个问题)(这种情况很少发生),他们不确定这些异常可能属于前两类中的哪一类。即使在同一个程序中,在一处 EOFException 也可能表明程序完全失败。在另一种情况下,这可能是查明文件已被读取的正常方法。所以最终的结果是大量的异常,它们既完成了这两项工作,又做得很差,迫使程序员使用try and catch and throws当他们无论如何都无法做任何事情并向他们提供他们不需要的复杂堆栈跟踪时。

添加:我应该明确指出,您可以通过简单地接受您已完成读取文件并继续操作来从真正的 EOFException 中恢复,可能使用break中的声明catch堵塞。然而,还有其他正确的方法来捕获 EOF,因此 EOFException 通常意味着像 NullPointerException 这样的真正问题。奇怪的是,我使用 NumberFormatException 的方式,我认为should被检查。当我想要一个号码时得到“AAA”是很常见的,这是用户错误,而不是编程错误。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

什么时候应该选择检查异常/非检查异常? 的相关文章

随机推荐

  • 切换类并从所有其他元素中删除类

    如何切换类并从所有其他元素中删除类 考虑一个包含标签的 div html div class size a href blahblah a a href blahblah a div jQuery size a click function
  • RStudio:在编写 RMarkdown 文档时禁用源窗口中代码的输出

    我最近更新了 RStudio 在源窗口中编写 R Markdown 文档时 每当我在 RMD 块中运行代码时 输 出都会以以下方式显示在源窗口本身中 当有巨大的情节时 它会变得太混乱 如果可能的话 希望禁用此功能并恢复为仅在控制台 绘图查看
  • 如何防止 Javadoc 中出现包私有接口?

    我有一堂这样的课 package org jjerms thing interface IThing void doSomething final class Thing implements IThing This Javadoc pre
  • DeleteFile 对最近关闭的文件失败

    我有一个单线程程序 C Win32 NTFS 它首先创建一个相当长的临时文件 关闭它 打开读取 读取 再次关闭并尝试使用删除DeleteFile 通常情况下进展顺利 但有时DeleteFile 失败 并且GetLastError 返回 ER
  • WTForms 使用 SelectField“解压太多值”

    我正在使用 WTForms 我正在尝试显示SelectField 但我收到以下错误 gt gt gt form status Traceback most recent call last File
  • boost::asio get_io_service() boost 1.70+ 中的替代方案

    我想使用一个图书馆 https github com onlinecity cpp smpp https github com onlinecity cpp smpp 并且它基于 boost 1 41 但在我们的项目中 我们使用的是 1 7
  • 当应用程序在后台或未运行时,推送通知无法正常工作

    我正在使用 Firebase Cloud Messaging 发送推送通知 这是我的FirebaseMessageService public class FireBaseMessageService extends FirebaseMes
  • 是否可以使用 jQuery 来调用 Google 地图 API?

    以下不起作用 get http maps googleapis com maps api geocode json sensor false region nz address queen function response console
  • 是否有可能在任何地方抛出异常的 STL 容器方法列表?

    我知道 STL 会抛出内存分配错误 或者如果包含的类型在其构造函数 赋值运算符中抛出异常 否则 显然 一些 STL 方法可能会引发其他异常 每个人似乎都提到的示例是 vector at 但我在任何地方都找不到其他示例的列表 有谁知道这样的清
  • WPF 应用程序中的 Log4Net 设置

    我不敢相信我不得不问这个 但这里是 我正在尝试在新的 WPF 应用程序中设置 log4net 但由于某种原因 它没有创建日志文件并记录任何内容 所以这是我到目前为止所做的步骤 添加来自 nuget 的最新版本 v2 0 8 0 参考后 在
  • Java相当于app.config?

    Java 中是否有相当于 NET 的 App Config 的工具 如果没有 是否有标准方法来保留应用程序设置 以便在应用程序分发后可以更改它们 对于 WebApps web xml 可用于存储应用程序设置 除此之外 您还可以使用特性 ht
  • Excel VBA:使用公式自动填充多个单元格

    我有从不同文件中收集的大量数据 在本主要工作簿中 我为每个单元格设置了不同类型的公式 范围 A 到 F 是收集其他文件的数据的位置 在 H 到 AC 范围内 我有一个公式 每次输入新数据时 我都会通过手动向下拖动来自动填充公式 下面的代码是
  • Spring Security Java Config 多组搜索库

    我正在使用带有 Java 配置和 LDAP 身份验证 授权的 Spring Security 3 2 5 我们需要在 LDAP 中的两个单独的树中搜索组 ou 组 and ou 组 ou webapps ou 应用程序 我进行了搜索 但无法
  • 如何将 numpy NaN 对象转换为 SQL null?

    我有一个 Pandas 数据框 正在将其插入到 SQL 数据库中 我直接使用 Psycopg2 与数据库对话 而不是 SQLAlchemy 所以我不能使用 Pandas 内置的 to sql 函数 几乎一切都按预期工作 除了 numpy n
  • 不同区域的VNET地址空间可以重叠吗?

    我刚刚在美国西部创建了一个地址空间为 10 0 0 0 16 的新 VNET 但在 Azure 门户上收到警告 地址空间 10 0 0 0 16 与虚拟网络 xxx 中的 10 0 0 0 16 重叠 VNET xxx 之前已在另一个区域创
  • 如何停止将文件夹名称存储在 Django 的数据库中?

    我正在将图像上传到我的特定文件夹中 但它也存储在我的数据库表中 请让我知道如何停止文件夹名称存储在数据库中 目前我的图像以这种格式存储在我的数据库表中thumb 20 08 18 image jpeg 我不想要这个thumb 20 08 1
  • 选择包含多个商品的所有订单并检查所有商品状态

    我有 2 张桌子 Orders Id Status 1 OK 2 WAITING 3 WAITING 4 OK 5 OK 6 OK 和订单详细信息 Id Order Id Status 1 1 S1 2 1 S1 3 2 S1 4 4 S2
  • Bash 循环中的计数器增量不起作用

    我有以下简单的脚本 我正在运行一个循环并想要维护一个COUNTER 我无法弄清楚为什么计数器没有更新 是由于正在创建子外壳吗 我怎样才能解决这个问题 bin bash WFY PATH var log nginx WFY FILE erro
  • 在 MVVM 应用程序中切换 ViewModel 时出现 BindingExpression 路径错误

    首先 先了解一些背景 如果您熟悉该问题 请跳至BindingExpression部分 这是我在 WPF 中的第一个主要项目 所以我对 MVVM 模式还很陌生 Here https stackoverflow com questions 16
  • 什么时候应该选择检查异常/非检查异常?

    我从各种教程中了解到 如果可以合理地期望客户端从异常中恢复 则将其设置为受检查的异常 如果客户端无法执行任何操作来从异常中恢复 则将其设置为未检查的异常 我很想通过一些代码示例来看看前面的语句的有效性 例如 try br readLine