ByVal or ByRef - As Variant


Integers

When you declare a variable with an Integer data type it can be passed in using either ByVal or ByRef.
When you declare a variable with a Variant data it can be passed in using either ByVal or ByRef.



Arrays

There is a difference between declaring a variable with a Variant data type as opposed to an Array data type.
When you declare a variable with an Array data type it can only be passed in using ByRef.
When you declare a variable with a Variant data type it can be passed in using either ByVal or ByRef.

Sub MySubroutine1() 
   Dim var3 As Variant
   var3 = Array(1, 2, 3, 4)
    
   MyFunc_1a (var3)
   Debug.Print var3(2) '3

   MyFunc_1b (var3)
   Debug.Print var3(2) '3
End Sub

Public Function MyFunc_1a(ByVal var4 As Variant)
   var4(2) = 4
End Function
Public Function MyFunc_1b(ByRef var4 As Variant)
   var4(2) = 8
End Function

Collections


Classes

When you declare a variable with a Class data type it can be passed in using either ByVal or ByRef.
When you declare a variable with a Variant data type it can only be passed in using either ByVal.

'myClass module
Private mstrPropertyName As String

Property Get Property_Name() As String
    Property_Name = mstrPropertyName
End Property

Property Let Property_Name(rData As String)
    mstrPropertyName = rData
End Property

When you declare a variable with a Variant data type it can only be passed in using ByVal.

Sub MySubroutine3() 
   Dim var5 As Variant
   Set var5 = New myClass
   var5.Property_Name = "before"
   Debug.Print var5.Property_Name

   MyFunc_3a (var5)
   Debug.Print var5.Property_Name
End Sub

'must be ByVal
Public Function MyFunc_3a(ByVal var6 As Variant)
   var6.Property_Name = "after"
End Function

User Defined Types



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