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
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
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 inspect the IL output of the 2 statements, they are the same. However, since ’return’ is meant for pushing something back to the caller, so strictly speaking, ‘Exit Sub’ is more suitable for using in a Sub.
Exit Sub
, HOWEVER it is specific to Visual Basic; return
is used to exit from subroutines in all languages inspired by C
: C#
, java
, C++
, Objective-C
. –
Indicative They are the same in this context.
However, from the code readability point of view, "Exit Sub" would be clearer since the "Return" indicates that something some value is being used as an output (which is not the case with Sub-routines).
Exit Sub
, HOWEVER it is specific to Visual Basic; return
is used to exit from subroutines in all languages inspired by C
: C#
, java
, C++
, Objective-C
. Downvoted because this says the same thing as chikani's answer two years earlier, so adds nothing to the discussion. –
Indicative CalcFact(X)
.Do some processes for a specific task.
Function is a specific process programmed to achieve a specific task by also passing some specific parameters, and it has to return some value that can be used to to complete the overall task, such as validation the user name and user pass.
In short Sub Doesn't return value and we call it directly "Print HelloWorld()"
, whereas functions do such as:
ValidUsersNameAndPass("Johne","jOhNe13042019")
' This could return a Boolean value. ValidUsersNameAndPass("Johne","jOhNe13042019");
// This could return a Boolean value. I wanted to confirm that they act the same in lambda expressions too, and they do:
Sub test()
Dim a As Action = Sub() Exit Sub
Dim b As Action = Sub() Return
a()
b()
MsgBox("Yes they do!")
End Sub
While there are exceptions like guard clauses, in most cases I would consider either a sign that the method is too long.
© 2022 - 2024 — McMap. All rights reserved.