Comprendre la différence entre ByVal et ByRef en VBA

Lorsque vous développez en VBA (Visual Basic for Applications), il est essentiel de bien saisir la façon dont les arguments sont passés aux ou aux procédures. Les deux principales méthodes sont le passage par valeur ( ByVal) et le passage par référence ( ByRef). Chacune de ces méthodes a des implications sur la manière dont les variables sont manipulées dans votre code. Ce guide vous explique ces concepts en détail, afin de comprendre la différence entre ByVal et ByRef en VBA.

Pour comprendre les différences subtiles entre ByVal et ByRef et leur impact sur vos macros, explorez notre formation pour maîtriser le code VBA qui aborde ces concepts en profondeur.

Notion de passage « Par Valeur » et « Par Référence »

Dans les langages de programmation comme VBA, transmettre des arguments à une fonction ou une procédure courante. On distingue deux types de passage d’arguments :

  1. Passage par Valeur ( ByVal) : Avec ByVal, une copie de la variable est transmise à la fonction. Toute modification de cette variable dans la fonction n’affecte pas la variable d’origine dans l’appelant.
  2. Passage par Référence ( ByRef) : Avec ByRef, c’est la variable elle-même qui est transmise, ou plus précisément, une référence à la variable. Cela signifie que les modifications apportées à cette variable dans la fonction se répercutent directement sur la variable originale.

Explication

D’un point de vue technique :

  • Passage par Valeur ( ByVal) : La fonction reçoit uniquement le contenu de la variable sous forme de copie. Ainsi, toute modification apportée à cette variable à l’intérieur de la fonction n’affecte pas la variable d’origine. Par conséquent, après l’exécution de la fonction, la variable d’origine reste intacte.
  • Passage par Référence ( ByRef) : La fonction reçoit l’adresse mémoire de la variable d’origine. Cela signifie que toute modification de la variable au sein de la fonction modifie également la variable d’origine. Ainsi, après l’exécution de la fonction, la variable originale peut avoir été modifiée.

Passage par Valeur ( ByVal)

Private Sub ModifierValeur(ByVal chiffre As Long)
    chiffre = chiffre * 2
End Sub

Private Sub DemarrerProcessus()
    Dim montant As Long
    montant = 150
    ModifierValeur montant
    Debug.Print montant  ' Affiche 150, car la variable 'montant' n'a pas été modifiée
End Sub

Dans cet exemple, la variable montant est passée à la procédure ModifierValeur par valeur. Même si chiffre est modifié à l’intérieur de la procédure, montant reste inchangé après l’appel de la procédure.

Passage par Référence ( ByRef)

Private Sub AjusterValeur(ByRef valeur As Long)
    valeur = valeur - 30
End Sub

Private Sub InitialiserCalcul()
    Dim total As Long
    total = 200
    AjusterValeur total
    Debug.Print total  ' Affiche 170, car la variable 'total' a été modifiée
End Sub

Ici, la variable totalest passée par référence à la procédure AjusterValeur. Toute modification de valeur dans la procédure modifier directement total.

L’utilisation optionnelle en VBA

En VBA, l’utilisation de ByValet ByRef est optionnelle. Par défaut, VBA passe les arguments par référence ( ByRef). Par conséquent, les deux déclarations suivantes sont équivalentes :

Function Calculer(ByRef x As Integer) As Integer
    ' Code
End Function

Function Calculer(x As Integer) As Integer
    ' Code
End Function

Cependant, il est fortement recommandé de toujours préciser ou préciser ByVal dans ByRef vos déclarations de fonctions et de procédures. Cela rend votre code plus lisible et protège contre les modifications non souhaitées des variables.

Pourquoi utiliser explicitement ByVal ou ByRef ?

Indiquer ByVal ou ByRef préciser dans vos déclarations permet de clarifier vos intentions en tant que développeur et de prévenir les erreurs de modification accidentelle des variables. Si une fonction ou une procédure n’a pas besoin de modifier un argument, il est conseillé d’utiliser ByVal pour protéger la variable contre toute modification involontaire.

Valeurs de retour et usage avancé de ByRef

Un des usages les plus fréquents du passage par référence ( ByRef) est le retour de plusieurs valeurs à partir d’une fonction. Comme une fonction ne peut normalement retourner qu’une seule valeur, passer des arguments par référence permet de modifier plusieurs variables simultanément et de les « retourner ».

Voici un exemple pratique qui illustre comment utiliser cette technique pour calculer les dimensions d’un rectangle et retourner ces valeurs via ByRef :

Private Function CalculerDimensions(ByVal largeur As Double, ByVal longueur As Double, ByRef aire As Double, ByRef perimetre As Double) As Boolean
    aire = largeur * longueur
    perimetre = 2 * (largeur + longueur)
    CalculerDimensions = True
End Function

Private Sub TesterDimensions()
    Dim aireRect As Double, perimetreRect As Double
    
    If CalculerDimensions(5, 10, aireRect, perimetreRect) Then
        MsgBox "L'aire est de : " & aireRect & " et le périmètre est de : " & perimetreRect
    End If
End Sub

Dans cet exemple, la fonction CalculerDimensionsretourne deux valeurs : aireRectet perimetreRect, grâce au passage par référence ( ByRef).

Conclusion

Maîtriser la différence entre ByValet ByRefest essentiel pour tout programmeur VBA. En résumé, utilisez ByVallorsque vous ne souhaitez pas que la fonction ou la procédure modifie l’argument d’origine, et ByReflorsque vous avez besoin de cette modification. Toujours indiquer spécifiquement l’un ou l’autre pour rendre votre code plus clair et éviter les erreurs. En comprenant et en appliquant correctement ces concepts, vous pourrez écrire du code VBA plus robuste, sûr et facile à maintenir.

Pour éviter les pièges liés à l’utilisation de ByVal et ByRef, faites appel à un spécialiste Excel VBA qui saura coder en respectant les meilleures pratiques.