vbScript on error resume next容错使用心得

2019-01-16 04:02:43王冬梅

执行以上代码的结果:
13 - 型が一致しません。
main ....
可以看出,在函数中,aaaaaaaaaaa是故意制造的一个错误,其后的WScript.Echo "funcb ok"以及后面的代码都没有执行。但是,主程序中的WScript.Echo "main ...."语句是执行了的。就是说,在函数中如果某个语句出错,函数中后面的语句都不执行,直接执行调用函数的语句后面的语句。
2,On error resume Next如果在函数内定义,看下面的代码执行情况


funcb ‘函数调用
If err.Number <> 0 Then
errNum = Err.Number
errDesc = Err.Description
WScript.Echo errNum & " - " & errDesc
End If
WScript.Echo "main ...."
Sub funcb ‘函数定义
On error resume Next
aaaaaaaaaaaa '无效语句
WScript.Echo "funcb ok"
If err.Number <> 0 Then
errNum = Err.Number
errDesc = Err.Description
WScript.Echo errNum & " - " & errDesc
End If
End Sub
funcb ‘函数调用
If err.Number <> 0 Then
errNum = Err.Number
errDesc = Err.Description
WScript.Echo errNum & " - " & errDesc
End If
WScript.Echo "main ...."
Sub funcb ‘函数定义
On error resume Next
aaaaaaaaaaaa '无效语句
WScript.Echo "funcb ok"
If err.Number <> 0 Then
errNum = Err.Number
errDesc = Err.Description
WScript.Echo errNum & " - " & errDesc
End If
End Sub

执行结果如下:
funcb ok
13 - 型が一致しません。
13 - 型が一致しません。
main ....
可以看到,函数体内的err对象和调用它的主程序中都可以捕获到这个错误,这说明err对象是全局的,应该这么理解,err的作用范围在一个On error resume Next语句和一个On Error Goto 0之间有效。如果我们在funcb调用语句的后面在加一个无效语句,执行时会弹出错误msg框,说明函数体内的On error resume Next不能作用到函数体外。
以上是使用On error resume Next的一些体会,如果了解了上面两点,就可以较好的使用错误处理的功能了。

您可能感兴趣的文章:

VBS教程:VBscript语句-On Error 语句VBScript中On Error语句用法小结