javascript - 如何在 Javascript 中重新抛出异常,但保留堆栈?

标签 javascript exception exception-handling stack-trace callstack

在 Javascript 中,假设我想在发生异常时执行一些清理,但让异常继续向上传播堆栈,例如:

try {
  enterAwesomeMode();
  doRiskyStuff(); // might throw an exception
} catch (e) {
  leaveAwesomeMode();
  throw e;
}
doMoreStuff();
leaveAwesomeMode();

此代码的问题在于,捕获并重新抛出异常会导致到该点为止的堆栈跟踪信息丢失,因此如果随后再次捕获异常,在堆栈的较高位置,堆栈跟踪只会下降重新抛出。这很糟糕,因为这意味着它不包含实际引发异常的函数。

事实证明,try..finally 至少在 Chrome 中具有相同的行为(也就是说,问题不在于重新抛出,而是任何异常处理程序 block 的存在。)

有谁知道在 Javascript 中重新抛出异常但保留与之关联的堆栈跟踪的方法?如果做不到这一点,关于添加异常安全清理处理程序的其他方法的建议如何,同时还可以在发生异常时捕获完整的堆栈跟踪?

感谢任何指点:)

最佳答案

这是 Chrome 中的错误。重新抛出异常应该保留调用跟踪。

http://code.google.com/p/chromium/issues/detail?id=60240

我不知道有什么解决方法。

我没有看到 finally 的问题。在某些情况下,我确实看到异常在 finally 之后没有出现在错误控制台上,但似乎已在开发版本中修复。

关于javascript - 如何在 Javascript 中重新抛出异常,但保留堆栈?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3734236/

相关文章:

sql - 如何在过程执行期间跟踪异常错误消息

javascript - jQuery scrollTop() 不适用于 Firefox 中的 'body' 元素

javascript - 获取 HTML 对象 : why it doesn't work? 的路径/"unique selector"

c++ - 从线程抛出异常没有给出预期的结果

java - 如何在 Clojure 中使用自己的 Java 异常类?

python - 尝试自动化浏览器时 Selenium 中的 ElementNotInteractableException

javascript - 动态 onclick 在 chrome 中不起作用

javascript - 在 ember js 中的应用程序模板上设置 tagName

exception - Haskell 中的安全应用

c# - ACRA 类似于 C# .NET 的崩溃报告库