指定在执行 try 语句发生异常时执行的代码。
Catch [, OutputVar] Statement
Catch [, OutputVar] { Statements }
(可选) 用来存储异常值的变量名称.
发生异常时执行的命令或表达式.
每次使用 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.