ByVal or ByRef - Classes
The Class data type is a reference data type.
When you declare a variable with a Class data type it can be passed in using either ByRef or ByVal.
In VBA all reference data types are passed by reference although there is a subtle difference.
Although it is a Reference data type there is a subtle difference between passing ByRef vs ByVal 'myClassModule class module
'myClassModule
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
ByRef
Passing a class into a subroutine using ByRef allows the original class to the changed.
Public Sub Passing_Classes1()
Dim myClass As myClassModule
Set myClass = New myClassModule
myClass.Property_Name = "before"
Debug.Print myClass.Property_Name
Call ByReference(myClass)
Debug.Print myClass.Property_Name
End Sub
Public Function ByReference(ByRef theClass As myClassModule)
'this is the original
'the class has been passed by reference so this change is made to the original class
theClass.Property_Name = "after"
'the class has been passed by reference so this changes the original
'the new class reference will be passed back
'we can see this because the second Debug.Print displays "<blank>"
Set theClass = New myClassModule
End Function
ByVal
Passing a class into a subroutine using ByVal allows the original class to the changed.
Public Sub Passing_Classes2()
Dim myClass As myClassModule
Set myClass = New myClassModule
myClass.Property_Name = "before"
Debug.Print myClass.Property_Name
Call ByValue(myClass)
Debug.Print myClass.Property_Name
End Sub
Public Function ByValue(ByVal theClass As myClassModule)
'the class has been passed by value so this change is made to the original class
theClass.Property_Name = "after"
'the class has been passed by value so this changes just the local copy
'any changes made to the class reference (ie new assignment) is contained within the subroutine
'we can see this because the second Debug.Print display "after"
Set theClass = New myClassModule
End Function
What is the difference between ByVal and ByRef in the context of Class data types ?
There is a difference between declaring a variable with a Variant data type as opposed to a Class data type.
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext