返回介绍

Catch [v1.1.04+]

发布于 2020-11-08 02:37:57 字数 2200 浏览 1086 评论 0 收藏 0

指定在执行 try 语句发生异常时执行的代码。

Catch [, OutputVar]
    Statement
Catch [, OutputVar]
{
    Statements
}

参数

OutputVar

(可选) 用来存储异常值的变量名称.

Statement(s)

发生异常时执行的命令或表达式.

备注

每次使用 catch 都必须附属于 (与之关联) 它上面的 try 语句. catch总是附属于在它上面且离它最近的无主try语句,不过可以使用区块改变这种行为。

可以使用 One True Brace (OTB) 风格. 例如:

try {
    ...
} catch e {
    ...
}

运行时错误

try-catch 语句同样可以用来处理运行时错误. 有两类的运行时错误:设置 ErrorLevel 的那些和在显示错误消息后会让当前线程退出的那些。无法处理加载时错误,因为它们在 try 执行前已经发生了。为了能够向后兼容(及在一些时候的方便),在执行 try 区块产生运行时错误时才会抛出异常。大部分命令支持 try-catch;不过当命令执行成功时 ErrorLevel 仍然被置为 0。

存储在OutputVar(如果存在)中的值是包含下列字段的异常对象

What: 错误发生时正在或即将执行的命令或函数的名称.

File: 包含发生错误的语句的脚本文件的完整路径.

Line: 发生错误的语句行号.

Message:错误消息或 ErrorLevel 值。

Extra: 可用时包含错误的额外信息.

注意: 这些细节应该仅用于调试, 因为它们可以在将来的版本中改变.

相关

Try, Throw, Finally, Blocks

示例

请参阅 Try.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文