当你 throw 一个 catch考虑你在一个catch块抛出一个异常。在退出函数之前没有什么可以捕获你的throw。那“ finally”会运行吗?
index.js

控制台结果:

finally运行,即使并没有打印最后一个日志语句!
你可以看到finally有点特别;它允许你在抛出错误和离开函数之间运行,即使抛出catch块。
尝试没有捕获您是否知道如果您提供finally块,您也不需要提供catch块?你可能做到了,但值得一提!
接下来的问题是:即使在try块中没有出错,finally块也会被调用吗?如果您不确定,请取消注释编辑器底部的example()以查找。
index.js

是的,即使没有出错也会调用finally。
index.js

所以最后让你在异常发生时自己清理,但是什么时候什么都不会出错,你只是从函数中“返回”正常...在try块中
看看下面的例子。example()中的finally块是否可以运行,在已经命中了return语句?

总结:
try语句允许我们定义在执行时进行错误测试的代码块。
catch 语句允许我们定义当 try 代码块发生错误时,所执行的代码块。
finally 语句在 try 和 catch 之后无论有无异常都会执行。
try { tryCode - 尝试执行代码块}catch(error) { catchCode - 捕获错误的代码块} finally { finallyCode - 无论 try / catch 结果如何都会执行的代码块}
本文解析了JavaScript中try-catch-finally语句的行为,包括finally块在抛出异常和正常返回情况下的执行特性。
782

被折叠的 条评论
为什么被折叠?



