Both "Exit Sub" or "Return" seem to accomplish the same thing -- exit a subroutine. Is there any difference in how they work under the covers?
That is,
Private Sub exitNow() Exit Sub End Sub
or
Private Sub exitNow() Return End Sub
In visual basic, we can exit or terminate the execution of the do-while loop immediately by using Exit keyword. Following is the example of using Exit keyword in a do-while loop to terminate loop execution in a visual basic programming language.
Creating a subroutine involves two lines of code. Luckily though, the Visual Basic code editor is smart, and will insert the second line for you! A subroutine begins with the word "Sub", followed by a space, then a name identifying the subroutine. Two parentheses follow, which are used for a parameter list.
From the doc:
In a Sub or Set procedure, the Return statement is equivalent to an Exit Sub or Exit Property statement, and expression must not be supplied.
So they're the same in this context.
(Return (<value>)
is used in functions and property.get's. Obviously slightly different in that context).
I tend to prefer Return
over Exit Sub
. Because once in a while you change from Sub
to Function
. In this case Exit Sub
could be converted to Exit Function
, but this assumes that there was a previous assignment to the function name (alike VB 6), which most probably didn't happen. Return
would catch this situation - if the method should return a value, Return
with no argument will fail at compile time.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With