ByVal vs ByRef VBA

后端 未结 4 1977
离开以前
离开以前 2021-02-09 21:25

I\'ve tried to attempt something that was answered by JaredPar ByRef vs ByVal Clarification

ByVal in VB.NET means that a copy of the provided

相关标签:
4条回答
  • 2021-02-09 21:50

    i can't remember where i read this, but i know that if you add the bracets () to arguments when calling a sub/function, it is a specific (not an error) way microsoft implented to workaround byref calls (to byval).

    example : lets say you call a sub who has ONLY byref, and 2 arguments:

    call Sub1 (a), (b)

    is a proper way to force Byvalarguments, even if they were initially coded as Byval

    0 讨论(0)
  • 2021-02-09 22:00

    Change this:

    testingRoutine (trythis)

    to this:

    testingRoutine trythis

    then try it.

    Also, look what happens if I change it to this, where the function is being used as a function (returning something)

    Sub test1()
    
        Dim trythis As Boolean
        Dim testit As Boolean
    
        trythis = False
    
        If (Sheets("Sheet1").Range("A1").Value = 1) Then
            testit = testingRoutine(trythis)
            If (trythis) Then
                Debug.Print "Value changed to 0"
                Sheets("TESTING").Range("A1").Value = 0
            End If
        End If
    
    End Sub
    
    Private Function testingRoutine(ByRef trythis As Boolean) As Boolean
    
        Debug.Print "Ran Function"
        trythis = True
    
    End Function
    
    0 讨论(0)
  • 2021-02-09 22:08

    I would do it this way.

    Sub test1()
    
        Dim trythis As Boolean
    
        trythis = False
    
        If (Sheets("TESTING").Range("A1").value = 1) Then
            tr = testingRoutine(trythis)
            If tr Then
                Debug.Print "Value changed to 0"
                Sheets("TESTING").Range("A1").value = 0
            End If
        End If
    
    End Sub
    
    Private Function testingRoutine(ByRef trythis As Boolean)
    
        Debug.Print "Ran Function"
        testingRoutine = True
    
    End Function
    

    Because trythis is not a global variable, changing it in the function will do nothing in the sub. It will just define trythis as True in the function and stay in that scope. To get trythis to be affected by the function and read by the sub you have to assign it to a variable within the sub.

    0 讨论(0)
  • 2021-02-09 22:09

    VB subroutines don't require braces around the argument list. However, if you pass a single argument and you enclose that in braces, you are passing an expression . Expressions cannot be passed by reference. They are evaluated and their result is passed. Therefore you must remove the braces in the call testingRoutine (trythis) and write testingRoutine trythis

    Note: if you call a function without using its return value, it must be written as a procedure call (without braces around the argument list). As an example:

    myVal = myFunction (trythis)   ' trythis will be passed by reference
    myFunction (trythis)           ' trythis will be seen as an expression
    myFunction trythis             ' trythis will be passed by reference
    
    myVal = mySub (trythis)        ' invalid: mySub is not a function
    mySub (trythis)                ' trythis will be seen as an expression
    mySub trythis                  ' trythis will be passed by reference
    

    Of course, the problem will be clear immediately when a function or sub has more than one parameter because a comma cannot appear in an expression.

    0 讨论(0)
提交回复
热议问题