- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
因此,我一直在研究应该如何进行try-catch-finally块,并且在阅读的每篇文章中都有一些相互矛盾的信息。有人可以澄清吗?
一个普遍的想法是,不要在代码中捕获不知道该如何处理的异常。如果没有其他异常捕获,异常将冒泡直到它可能到达全局异常处理程序。因此,此时您会向用户显示一条消息,指出发生了未知类型的异常,将其记录下来,等等。
现在看来,这是您唯一需要的异常处理程序?您不应该将其用于流程控制,因此您应该检查是否返回某些内容为null或无效导致异常并在代码中对其进行更正。即。测试null并对其进行一些处理,然后才能引起异常。
但是,还有其他一些事情,例如内存不足,您将无法测试它们,它只会在操作期间发生,并且会引发异常。但是我也将对此无能为力,因此这将被发送给全局处理程序。
我认为我缺少一些东西,例如在处理文件时,外部代码可能会抛出一些东西。文件未找到异常似乎经常出现,因此我会抓住它,并在finally块中正常关闭我打开的与其他代码/处理相关的所有内容,然后通知用户并立即将其记录在这里?
为什么要捕获异常的唯一原因是要确保该块的最后一部分能够确保在已知状态下关闭/确定该异常之前启动的所有内容?但是即使那样,您仍然希望在执行完这些任务后抛出此异常,以便全局异常处理程序通知用户,这时没有必要复制此代码吗?
因此,除了全局异常处理程序之外,您还可以针对这些情况尝试try-catch-finally块。
因此,假设我在这里遗漏了一些东西,则可能有可能您想要尝试捕获特定类型的异常,然后对其进行处理。我无法想到您想要在catch块中执行的任何操作,因为全局操作会记录/通知用户,并且如果您有异常,通常意味着没有任何代码可以继续处理。
有什么简单的方法可以知道哪些模块会抛出哪些异常?我认为我已读过的唯一方法是阅读MSDN或组件供应商文档,除了无法知道要查找的特定异常(无法确定为什么)之外,没有其他方法可以知道。
出现此问题是因为在我的应用程序中,我在try-catch块中有一段代码,最终导致发生异常时,这是因为对象为null或字符串无效。一旦我编写了处理这些情况的代码,就不再需要try-catch块,如果现在遇到异常,则代码无法执行任何恢复操作,因此应对其进行记录并让用户知道,以便对其进行修复。
但这与我一直在阅读和向我宣讲的东西背道而驰,错误的代码是没有try-catch块的代码。那么,这一切如何联系在一起,我在这里想念的是什么?
最佳答案
问题的第一部分是完全正确的:您应该只捕获知道如何处理的异常。否则,只要让它们冒泡,直到它们到达可以处理它们的代码为止。
(请注意,“句柄”并不表示“日志”或“显示错误”。它是指纠正导致异常的问题或以某种方式解决该异常。)
如果它们从未遇到可以处理它们的代码,或者它们是不可处理的异常(例如OutOfMemory),则它们最终将到达全局未处理的异常处理程序。在这里,您将记录异常(如果适用),向用户显示一般错误(如果适用),并且经常(在不常见的情况下)终止应用程序。您不能像没有任何反应一样简单地继续操作-异常表明应用程序处于意外状态。如果尝试并继续,那只会崩溃,甚至更糟。
我认为我缺少一些东西,例如在处理文件时,外部代码可能会抛出一些东西。文件未找到异常似乎经常出现,因此我将捕获该异常,并在finally块中正常关闭我打开的与其他代码/处理相关的所有内容,然后通知用户并立即将其登录?
FileNotFound是您要在本地处理的异常的一个很好的例子。在尝试加载文件的相同方法(或UI代码中的上一层)中,您将拥有一个FileNotFound异常的catch
块。如果合适,向用户显示友好的错误消息,并要求他们选择另一个文件。如果是内部代码,请放弃并尝试其他操作。无论您需要做什么。 FileNotFound在代码之外冒泡的原因很少。
这有点像使用异常进行流控制,但这是不可避免的。无法避免对I / O使用异常(或错误代码),因此您只需要处理故障情况即可。您可以先尝试验证文件是否存在,然后再尝试打开它,但这不能解决竞标问题,因为在您运行验证代码与实际尝试打开文件之间,文件被删除或无法访问。因此,现在您要做的就是在两个地方复制错误处理代码,这几乎没有用。
您必须在本地处理类似FileNotFound的异常。离抛出的代码越远,您对它进行任何合理的选择的可能性就越小。
除了与I / O相关的异常外,另一个很好的例子是NotSupportedException。例如,如果尝试调用不支持的方法,则可能会遇到此异常。您可能会想要处理它,并在catch
块中保存代码,这可以作为一种安全的选择。
为什么要捕获异常的唯一原因是要确保该块的最后一部分能够确保在已知状态下关闭/确定该异常之前启动的所有内容?但是即使那样,您仍要在执行完这些任务后引发此异常,以便全局异常处理程序通知用户,这时没有必要复制此代码吗?
这不需要捕获异常。您可以只有一个try
块才有一个finally
块。不需要catch
块。实际上,这正是using
语句实现的。如果您有在抛出异常的情况下需要清除的状态,则应实现IDisposable
模式并将该对象的用法包装在using
块中。
有什么简单的方法可以知道哪些模块会抛出哪些异常?我认为我已读过的唯一方法是阅读MSDN或组件供应商文档,除了无法知道要查找的特定异常(无法确定原因)之外,没有其他方法。
恰恰。但是,这并不是真正的问题,因为您只捕获了可以做些事情的异常。如果您不知道某个模块会引发特定的异常,那么显然您就不会编写处理该异常的代码。
该文档将告诉您可能需要处理的所有重要异常,例如FileNotFound,SecurityException或您所拥有的。
出现此问题是因为在我的应用程序中,我在try-catch块中有一段代码,最终导致发生异常时,这是因为对象为null或字符串无效。一旦我编写了处理这些情况的代码,就不再需要try-catch块,如果现在遇到异常,该代码将无法恢复,因此应对其进行记录并让用户知道,以便对其进行修复。
首先,避免例外始终是最好的选择。例如,如果您可以设计应用程序,使得不可能有null对象或无效字符串,那就太好了。这就是我们所谓的健壮代码。在这种情况下,您无需捕获这些异常,因为您无法处理它。您以为您已经解决了该问题,因此,无论如何,如果引发异常,则表明存在错误。不要用catch
块掩盖它。
但是有时候,仍然需要catch
块,您可以在catch
块内编写代码来解决该问题。在这种情况下,可能没有理由重新抛出异常或将其记录下来,因此您没有任何代码重复。
但这与我一直在阅读和向我宣讲的东西背道而驰,错误的代码是没有try-catch块的代码。那么,这一切如何联系在一起,我在这里错过了什么?
完全错误。我不知道你在哪里读,但这是胡扯。例外是例外情况。如果您的代码各处都散布着catch
块,则表明您做错了。您是在使用异常进行流控制,还是在误导性地吞下异常以“提高可靠性”,或者您不了解全局未处理的异常处理程序。
听起来不像我在想什么。
我不得不提到的唯一不完全符合您的任何问题的事情是,有时您可能想捕获一个异常并将其作为另一个异常重新抛出。最常见的情况是设计一个可重用的代码库。在库内部,您可能会捕获内部异常,如果无法处理它们,请将它们作为常规异常重新抛出。库的重点是封装,所以您不应让异常冒出来,以至于调用者可能无能为力。
关于c# - Try Catch应该使用,除非永远不要使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24300708/
我想知道是否可以安全地编写 catch() 来捕获所有 System.Exception 类型。或者我是否必须坚持使用 catch(Exception) 来完成此任务。我知道对于其他异常类型(例如 I
在 C# 中,'Catch'、'Catch (Exception)' 和 'Catch(Exception e)' 之间有什么区别? MSDN article on try-catch在其示例中使用了
然后一个 Promise 调用另一个 Promise,并且内部 Promise 从 catch .then block 中的外部 Promise 返回 我一般都在这里和谷歌上搜索过。尝试使用简单的 t
我们可以在 Try-Catch 中使用多个 catch 块。 但我的问题是:为什么可以使用单个 catch 块完成时使用多个 catch 块? 假设我想要我的问题的确切原因,我可以通过 Ex.mess
所以我在 service.ts 中有这个用户服务功能其中包括数据库的东西。 export const service = { async getAll(): Promise { try {
我不确定这里发生了什么。很明显为什么内扣会捕获throw 2 ,但为什么外面catch(int x)捕获 throw ?我以为catch(int x)应该只捕获整数值。第二个throw有可能吗?抛出什
我目前正在以不同的方式加载图像,如下所示: try { // way 1 } catch { // way 1 didn't work try { // way 2 }
这两者有什么区别?一个比另一个快吗?两者似乎都有效。有人请解释 没有 promise 的人: client.query(query1) .then(data => { callback(null
它几乎可以在所有语言中找到,而且我大部分时间都在使用它。 我不知道它是内部的,不知道它是如何真正起作用的。 它如何在任何语言的运行时在 native 级别工作? 例如:如果在 try 内部发生 sta
Closed. This question is opinion-based。它当前不接受答案。 想改善这个问题吗?更新问题,以便editing this post用事实和引用来回答。 1年前关闭。
我正在编写一个用于学习目的的短代码,要求用户输入密码才能登录 Facebook。我正在测试异常处理,由于某种原因,当密码错误时,Catch 部分没有执行。代码是: import java.util.S
如果try-catch的catch block 中抛出异常,那么finally block 会被调用吗? try { //some thing which throws error } cat
try { while ((inputLine = bufferedReader.readLine()) != null) { String[] words = inputLine.s
在 C# 上下文中,可以使用如下代码: try { ... } catch { ... } 在其他情况下,代码可以是: try { ... } catch (Exc
有时我在探索 ServiceStack 的代码库时遇到以下构造: try { ... } catch (Exception) { throw; } 在我看来,这种结构没有任何作用。这样做的
我最近遇到了一个 Javascript 问题,捕获错误,因此在抛出异常时崩溃。 funcReturnPromise().then().catch() 我必须将其更改为: try { funcRet
我在编写一些测试的 C++ 文件中遇到此错误: error: no member named 'Session' in namespace 'Catch' testResult = C
CException 是VC++抛出的所有异常的基类型,所以它应该捕获所有的异常吧? 最佳答案 CException 不是所有扩展的基类型(它可能是 MFC 代码使用的所有异常的基类型,但仅此而已)。
每次我看到 catch all 语句时: try { // some code } catch (...) { } 它一直是一种滥用。 反对使用 cache all 子句的论点是显而易见的。它会捕
代码相当简单——问题是 groupPath 字符串中有一个无效字符(准确地说是“/”)。 我正在尝试做的(至少作为权宜之计)是跳过我无法获得 cn 的 DirectoryEntries --- 不管为
我是一名优秀的程序员,十分优秀!