Get (Instrucción)

Actualización: noviembre 2007

Declara un procedimiento de propiedad Get que se utiliza para recuperar el valor de una propiedad.

[ <attributelist> ] [ accessmodifier ] Get()
    [ statements ]
End Get

Partes

  • attributelist
    Opcional. Vea Lista de atributos.

  • accessmodifier
    Opcional en, como máximo, una de las instrucciones Get y Set de esta propiedad. Puede ser una de las siguientes:

    Vea Niveles de acceso en Visual Basic.

  • statements
    Opcional. Una o más instrucciones que se ejecutan cuando se llama al procedimiento de propiedad Get.

  • End Get
    Obligatorio. Termina la definición de este procedimiento de propiedad Get.

Comentarios

Cada propiedad debe tener un procedimiento de propiedad Get, a menos que la propiedad esté marcada como WriteOnly. El procedimiento Get se utiliza para devolver el valor actual de la propiedad.

Visual Basic llama automáticamente al procedimiento Get de una propiedad cuando una expresión solicita el valor de la propiedad.

El cuerpo de la declaración de propiedad puede contener sólo los procedimientos Get y Set de la propiedad entre la instrucción Property (Instrucción) y la instrucción End Property No puede almacenar nada que no sean esos procedimientos. En concreto, no puede almacenar el valor actual de la propiedad. Debe almacenar este valor fuera de la propiedad porque, si lo guarda dentro de cualquiera de los procedimientos de propiedad, el otro procedimiento de propiedad no puede tener acceso a ella. El enfoque usual es almacenar el valor en una variable Private (Visual Basic) declarada en el mismo nivel que la propiedad. Debe definir un procedimiento Get dentro de la propiedad a la que se aplica.

El procedimiento Get tiene como valor predeterminado el nivel de acceso de su propiedad contenedora a menos que utilice accessmodifier en la instrucción Get.

Reglas

  • Niveles de acceso mixto. Si está definiendo una propiedad de lectura y escritura, tiene la opción de especificar un nivel de acceso distinto para el procedimiento Get o para el procedimiento Set, pero no para ambos. Si así lo hace, el nivel de acceso del procedimiento debe ser más restrictivo que el nivel de acceso de la propiedad. Por ejemplo, si la propiedad se declara como Friend, puede declarar el procedimiento Get como Private, pero no como Public.

    Si está definiendo una propiedad ReadOnly, el procedimiento Get representa toda la propiedad. No puede declarar un nivel de acceso diferente para Get, porque se establecerían dos niveles de acceso para la propiedad.

  • Tipo de valor devuelto. La instrucción Property (Instrucción) puede declarar el tipo de datos del valor que devuelve. El procedimiento Get devuelve automáticamente ese tipo de datos. Puede especificar cualquier tipo de datos o el nombre de una enumeración, estructura, clase o interfaz.

    Si la instrucción Property no especifica returntype, el procedimiento devuelve Object.

Comportamiento

  • Retorno de un procedimiento. Cuando el procedimiento Get vuelve al código de llamada, la ejecución continúa dentro de la instrucción que solicitó el valor de la propiedad.

    Los procedimientos de propiedad Get pueden devolver un valor mediante la instrucción Instrucción Return (Visual Basic) o asignando el valor devuelto al nombre de propiedad. Para obtener más información, vea "Valor devuelto" en Instrucción Function (Visual Basic).

    Las instrucciones Exit Property y Return provocan una salida inmediata de un procedimiento de propiedad. Puede aparecer cualquier cantidad de instrucciones Exit Property y Return en cualquier parte del procedimiento, y se puede combinar instrucciones Exit Property y Return.

  • Valor devuelto. Para devolver un valor desde un procedimiento Get, puede asignar el valor al nombre de propiedad o incluirlo en una instrucción Instrucción Return (Visual Basic). La instrucción Return asigna simultáneamente el valor devuelto por el procedimiento Get y sale del procedimiento.

    Si utiliza Exit Property sin asignar un valor al nombre de propiedad, el procedimiento Get devuelve el valor predeterminado para el tipo de datos de la propiedad. Para obtener más información, vea "Valor devuelto" en Instrucción Function (Visual Basic).

    El ejemplo siguiente muestra dos maneras en que la propiedad quoteForTheDay de sólo lectura puede devolver el valor contenido en la variable privada quoteValue.

    Private quoteValue As String = "No quote assigned yet."
    
    ReadOnly Property quoteForTheDay() As String
        Get
            quoteForTheDay = quoteValue
            Exit Property
        End Get
    End Property
    
    ReadOnly Property quoteForTheDay() As String
        Get
            Return quoteValue
        End Get
    End Property
    

Ejemplo

En el ejemplo siguiente se utiliza la instrucción Get para devolver el valor de una propiedad.

Class propClass
    ' Define a private local variable to store the property value.
    Private currentTime As String
    ' Define the read-only property.
    Public ReadOnly Property dateAndTime() As String
        Get
            ' The Get procedure is called automatically when the
            ' value of the property is retrieved.
            currentTime = CStr(Now)
            ' Return the date and time As a string.
            Return currentTime
        End Get
    End Property
End Class

Vea también

Tareas

Cómo: Agregar campos y propiedades a una clase

Referencia

Instrucción Set (Visual Basic)

Property (Instrucción)

Instrucción Exit (Visual Basic)