Share via


ByVal (Visual Basic)

Especifica que um argumento é passado de tal forma que o procedimento ou propriedade chamado não pode alterar o valor de uma variável subjacente ao argumento no código de chamada.

Comentários

O modificador ByVal pode ser utilizado nestes contextos:

Instrução Declare

Instrução de função (Visual Basic)

Instrução Operator

Instrução Property

Instrução Sub (Visual Basic)

Exemplo

O exemplo a seguir demonstra o uso da ByVal parâmetro mecanismo com um argumento de tipo de referência de passagem.No exemplo, o argumento é c1, uma instância da classe Class1.ByValimpede o código nos procedimentos de alteração do valor subjacente do argumento da referência, c1, mas não protege os campos acessíveis e propriedades do c1.

Module Module1

    Sub Main()

        ' Declare an instance of the class and assign a value to its field.
        Dim c1 As Class1 = New Class1()
        c1.Field = 5
        Console.WriteLine(c1.Field)
        ' Output: 5

        ' ByVal does not prevent changing the value of a field or property.
        ChangeFieldValue(c1)
        Console.WriteLine(c1.Field)
        ' Output: 500

        ' ByVal does prevent changing the value of c1 itself. 
        ChangeClassReference(c1)
        Console.WriteLine(c1.Field)
        ' Output: 500

        Console.ReadKey()
    End Sub

    Public Sub ChangeFieldValue(ByVal cls As Class1)
        cls.Field = 500
    End Sub

    Public Sub ChangeClassReference(ByVal cls As Class1)
        cls = New Class1()
        cls.Field = 1000
    End Sub

    Public Class Class1
        Public Field As Integer
    End Class

End Module

Consulte também

Conceitos

Passando argumentos por valor e por referência (Visual Basic)

Outros recursos

Palavras-chave (Visual Basic)