views:

2513

answers:

1

I have a test in Excel VBA:

If (test1) And (test2) And (test3) Then
    'do something
End If

In C, Java, etc. test1 would be run first, then test2, then test3. Critically, if test1 is false the whole test is false so the remaining tests aren't run.

Does that happen in this case? If so, which order are the tests running?

+4  A: 

In all VBs prior to .NET there is no such thing as short-circuit. All expressions will be evaluated even if not required. If you want short-curcuit, do nested IFs.

GSerg