Evaluated First

It is possible to evaluate the argument before it is passed into a subroutine or function.
This can be achieved by enclosing it inside its own parentheses.
This has nothing to do with the Call keyword.


Calling Subroutines

There are two ways to call a subroutine.
The first is to use the Call keyword in which case the arguments have to appear in parentheses.
The second is to not use the Call keyword in which case the arguments DO NOT have to appear in parentheses.

Call Integer_ByVal(var1) 
Integer_ByVal var1

You can enclose arguments inside there own set of parentheses to force them to be evaluated first.

Call Integer_ByVal((var1)) 
Integer_ByVal (var1)

If you are not using the Call keyword this implicit evaluation is harder to spot.


Example

The following snippets demonstrates that when you enclose your variables in parentheses you get different results.
You should always try and use the Call keyword when you are passing control to a subroutine to avoid confusion.

Sub Integers_AsIntegers() 
   Dim var1 As Integer
   
   var1 = 100
   Call Integer_ByVal(var1)
   Debug.Print var1 '100

   var1 = 100
   Call Integer_ByRef(var1)
   Debug.Print var1 '300
   
'Variables are evaluated first when enclosed in parentheses
   var1 = 100
   Integer_ByRef (var1)
   Debug.Print var1 '100
   
'Variables are evaluated first when enclosed in parentheses
   var1 = 100
   Call Integer_ByRef((var1))
   Debug.Print var1 '100
End Sub

Public Function Integer_ByVal(ByVal var2 As Integer)
   var2 = 200
End Function
Public Function Integer_ByRef(ByRef var2 As Integer)
   var2 = 300
End Function

© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext