Nota
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
Una instrucción en Visual Basic es una instrucción completa. Puede contener palabras clave, operadores, variables, constantes y expresiones. Cada declaración pertenece a una de las siguientes categorías:
Instrucciones de declaración, que asignan un nombre a una variable, una constante o un procedimiento, y también pueden especificar un tipo de datos.
Instrucciones Executable, que inician acciones. Estas instrucciones pueden llamar a un método o función, y pueden recorrer en bucle o ramificarse a través de bloques de código. Las instrucciones ejecutables incluyen instrucciones de asignación, que asignan un valor o expresión a una variable o constante.
En este tema se describe cada categoría. Además, en este tema se describe cómo combinar varias instrucciones en una sola línea y cómo continuar una instrucción en varias líneas.
Instrucciones de declaración
Las instrucciones de declaración se usan para nombrar y definir procedimientos, variables, propiedades, matrices y constantes. Al declarar un elemento de programación, también puede definir su tipo de datos, nivel de acceso y ámbito. Para obtener más información, vea Características de elemento declaradas.
En el ejemplo siguiente se incluyen tres declaraciones.
Public Sub ApplyFormat()
Const limit As Integer = 33
Dim thisWidget As New widget
' Insert code to implement the procedure.
End Sub
La primera declaración es la instrucción Sub
. Junto con su instrucción coincidente End Sub
, declara un procedimiento denominado applyFormat
. También especifica que applyFormat
es Public
, lo que significa que cualquier código que pueda hacer referencia a él puede llamarlo.
La segunda declaración es la Const
instrucción , que declara la constante limit
, especificando el Integer
tipo de datos y un valor de 33.
La tercera declaración es la Dim
instrucción , que declara la variable thisWidget
. El tipo de datos es un objeto específico, es decir, un objeto creado a partir de la Widget
clase . Puede declarar una variable para que sea de cualquier tipo de datos elemental o de cualquier tipo de objeto que se exponga en la aplicación que esté usando.
Valores iniciales
Cuando se ejecuta el código que contiene una instrucción de declaración, Visual Basic reserva la memoria necesaria para el elemento declarado. Si el elemento contiene un valor, Visual Basic lo inicializa en el valor predeterminado para su tipo de datos. Para más información, consulte "Comportamiento" en Instrucción Dim.
Puede asignar un valor inicial a una variable como parte de su declaración, como se muestra en el ejemplo siguiente.
Dim m As Integer = 45
' The preceding declaration creates m and assigns the value 45 to it.
Si una variable es una variable de objeto, puede crear explícitamente una instancia de su clase al declararla mediante la palabra clave New Operator , como se muestra en el ejemplo siguiente.
Dim f As New FileInfo("filename")
Tenga en cuenta que el valor inicial que especifique en una instrucción de declaración no se asigna a una variable hasta que la ejecución alcance su instrucción de declaración. Hasta ese momento, la variable contiene el valor predeterminado para su tipo de datos.
Instrucciones ejecutables
Una instrucción ejecutable realiza una acción. Puede llamar a un procedimiento, ramificarse a otro lugar del código, recorrer varias instrucciones o evaluar una expresión. Una instrucción de asignación es un caso especial de una instrucción ejecutable.
En el ejemplo siguiente se usa una If...Then...Else
estructura de control para ejecutar diferentes bloques de código en función del valor de una variable. Dentro de cada bloque de código, un For...Next
bucle ejecuta un número especificado de veces.
Public Sub StartWidget(ByVal aWidget As widget,
ByVal clockwise As Boolean, ByVal revolutions As Integer)
Dim counter As Integer
If clockwise = True Then
For counter = 1 To revolutions
aWidget.SpinClockwise()
Next counter
Else
For counter = 1 To revolutions
aWidget.SpinCounterClockwise()
Next counter
End If
End Sub
La If
instrucción del ejemplo anterior comprueba el valor del parámetro clockwise
. Si el valor es True
, llama al método spinClockwise
de aWidget
. Si el valor es False
, llama al método spinCounterClockwise
de aWidget
. La estructura de If...Then...Else
control termina con End If
.
El For...Next
bucle dentro de cada bloque llama al método adecuado un número de veces igual al valor del revolutions
parámetro.
Instrucciones de asignación
Las instrucciones de asignación llevan a cabo operaciones de asignación, que constan de tomar el valor en el lado derecho del operador de asignación (=
) y almacenarlo en el elemento de la izquierda, como en el ejemplo siguiente.
v = 42
En el ejemplo anterior, la instrucción de asignación almacena el valor literal 42 en la variable v
.
Elementos de programación aptos
El elemento de programación del lado izquierdo del operador de asignación debe poder aceptar y almacenar un valor. Esto significa que debe ser una variable o propiedad que no sea ReadOnly o debe ser un elemento de matriz. En el contexto de una instrucción de asignación, este elemento se denomina a veces lvalue, para "valor a la izquierda".
El valor del lado derecho del operador de asignación se genera mediante una expresión, que puede constar de cualquier combinación de literales, constantes, variables, propiedades, elementos de matriz, otras expresiones o llamadas de función. Esto se ilustra en el siguiente ejemplo:
x = y + z + FindResult(3)
En el ejemplo anterior se agrega el valor mantenido en la variable y
al valor mantenido en la variable z
y, a continuación, se agrega el valor devuelto por la llamada a la función findResult
. A continuación, el valor total de esta expresión se almacena en la variable x
.
Tipos de datos en instrucciones de asignación
Además de los valores numéricos, el operador de asignación también puede asignar String
valores, como se muestra en el ejemplo siguiente.
Dim a, b As String
a = "String variable assignment"
b = "Con" & "cat" & "enation"
' The preceding statement assigns the value "Concatenation" to b.
También puede asignar Boolean
valores mediante un Boolean
literal o una Boolean
expresión, como se muestra en el ejemplo siguiente.
Dim r, s, t As Boolean
r = True
s = 45 > 1003
t = 45 > 1003 Or 45 > 17
' The preceding statements assign False to s and True to t.
Del mismo modo, puede asignar valores adecuados a los elementos de programación de tipo de datos Char
, Date
o Object
. También puede asignar una instancia de objeto a un elemento declarado como de la clase desde la que se crea esa instancia.
Instrucciones de asignación compuestas
Las instrucciones de asignación compuestas realizan primero una operación en una expresión antes de asignarla a un elemento de programación. En el ejemplo siguiente se muestra uno de estos operadores, , +=
que incrementa el valor de la variable en el lado izquierdo del operador por el valor de la expresión a la derecha.
n += 1
En el ejemplo anterior se agrega 1 al valor de n
y, a continuación, se almacena ese nuevo valor en n
. Es un equivalente abreviado de la siguiente instrucción:
n = n + 1
Se pueden realizar diversas operaciones de asignación compuestas mediante operadores de este tipo. Para obtener una lista de estos operadores y más información sobre ellos, vea Operadores de asignación.
El operador de asignación de concatenación (&=
) es útil para agregar una cadena al final de cadenas ya existentes, como se muestra en el ejemplo siguiente.
Dim q As String = "Sample "
q &= "String"
' q now contains "Sample String".
Conversiones de tipos en instrucciones de asignación
El valor que asigne a una variable, propiedad o elemento de matriz debe ser de un tipo de datos adecuado para ese elemento de destino. En general, debe intentar generar un valor del mismo tipo de datos que el del elemento de destino. Sin embargo, algunos tipos se pueden convertir a otros tipos durante la asignación.
Para obtener información sobre la conversión entre tipos de datos, vea Conversiones de tipos en Visual Basic. En resumen, Visual Basic convierte automáticamente un valor de un tipo determinado en cualquier otro tipo al que amplía. Una conversión de ampliación es una en que siempre se realiza correctamente en tiempo de ejecución y no pierde ningún dato. Por ejemplo, Visual Basic convierte un Integer
valor en Double
cuando sea adecuado, ya que Integer
amplía a Double
. Para obtener más información, consulta Widening and Narrowing Conversions.
Las conversiones de reducción (aquellas que no son de ampliación) conllevan un riesgo de error en tiempo de ejecución o de pérdida de datos. Puede realizar una conversión de restricción explícitamente mediante una función de conversión de tipos, o bien puede dirigir al compilador para realizar todas las conversiones implícitamente estableciendo Option Strict Off
. Para obtener más información, vea Conversiones implícitas y explícitas.
Colocación de varias instrucciones en una línea
Puede tener varias instrucciones en una sola línea separadas por el carácter de dos puntos (:
). Esto se ilustra en el siguiente ejemplo:
Dim sampleString As String = "Hello World" : MsgBox(sampleString)
Aunque ocasionalmente resulta conveniente, esta forma de sintaxis hace que el código sea difícil de leer y mantener. Por lo tanto, se recomienda mantener una instrucción en una línea.
Continuación de una instrucción en varias líneas
Normalmente, una instrucción cabe en una línea, pero cuando es demasiado larga, puede continuarla en la siguiente mediante una secuencia de continuación de línea, que consta de un espacio seguido de un carácter de subrayado (_
) seguido de un retorno de carro. En el siguiente ejemplo, la instrucción ejecutable MsgBox
se extiende sobre dos líneas.
Public Sub DemoBox()
Dim nameVar As String
nameVar = "John"
MsgBox("Hello " & nameVar _
& ". How are you?")
End Sub
Continuación de línea implícita
En muchos casos, puede continuar una declaración en la siguiente línea sin usar el carácter de subrayado (_
). Los siguientes elementos de sintaxis continúan implícitamente la instrucción en la siguiente línea de código.
Después de una coma (
,
). Por ejemplo:Public Function GetUsername(ByVal username As String, ByVal delimiter As Char, ByVal position As Integer) As String Return username.Split(delimiter)(position) End Function
Después de un paréntesis abierto (
(
) o antes de un paréntesis de cierre ()
). Por ejemplo:Dim username = GetUsername( Security.Principal.WindowsIdentity.GetCurrent().Name, CChar("\"), 1 )
Detrás de una llave de apertura (
{
) o delante de una llave de cierre (}
). Por ejemplo:Dim customer = New Customer With { .Name = "Terry Adams", .Company = "Adventure Works", .Email = "terry@www.adventure-works.com" }
Para obtener más información, vea Inicializadores de objetos: Tipos con nombre y anónimos o inicializadores de colección.
Detrás de una expresión insertada de apertura (
<%=
) o delate de una expresión insertada de cierre (%>
) dentro de un literal XML. Por ejemplo:Dim customerXml = <Customer> <Name> <%= customer.Name %> </Name> <Email> <%= customer.Email %> </Email> </Customer>
Para más información, consulte Expresiones insertadas en XML.
Detrás del operador de concatenación (
&
). Por ejemplo:cmd.CommandText = "SELECT * FROM Titles JOIN Publishers " & "ON Publishers.PubId = Titles.PubID " & "WHERE Publishers.State = 'CA'"
Para obtener más información, consulte Operadores enumerados por funcionalidad.
Detrás de los operadores de asignación (
=
, ,&=
:=
,+=
,-=
*=
/=
\=
^=
<<=
,>>=
). Por ejemplo:Dim fileStream = My.Computer.FileSystem. OpenTextFileReader(filePath)
Para obtener más información, consulte Operadores enumerados por funcionalidad.
Después de los operadores binarios (
+
,-
,/
,*
,Mod
,<>
,<
,>
,<=
,>=
,^
,>>
,<<
,And
,AndAlso
,Or
,OrElse
,Like
,Xor
) dentro de una expresión. Por ejemplo:Dim memoryInUse = My.Computer.Info.TotalPhysicalMemory + My.Computer.Info.TotalVirtualMemory - My.Computer.Info.AvailablePhysicalMemory - My.Computer.Info.AvailableVirtualMemory
Para obtener más información, consulte Operadores enumerados por funcionalidad.
Después de los operadores
Is
yIsNot
. Por ejemplo:If TypeOf inStream Is IO.FileStream AndAlso inStream IsNot Nothing Then ReadFile(inStream) End If
Para obtener más información, consulte Operadores enumerados por funcionalidad.
Detrás de un carácter calificador de miembro (
.
) y delante del nombre del miembro. Por ejemplo:Dim fileStream = My.Computer.FileSystem. OpenTextFileReader(filePath)
Sin embargo, debe incluir un carácter de continuación de línea (
_
) después de un carácter calificador de miembro cuando use la instrucciónWith
o proporcione valores en la lista de inicialización para un tipo. Considere la posibilidad de dividir la línea después del operador de asignación (por ejemplo,=
) cuando se usanWith
instrucciones o listas de inicialización de objetos. Por ejemplo:' Not allowed: ' Dim aType = New With { . ' PropertyName = "Value" ' Allowed: Dim aType = New With {.PropertyName = "Value"} Dim log As New EventLog() ' Not allowed: ' With log ' . ' Source = "Application" ' End With ' Allowed: With log .Source = "Application" End With
Para más información, consulte Instrucción With... End With o Inicializadores de objetos: Tipos con nombre y anónimos.
Detrás de un calificador de propiedad del eje XML (
.
o.@
...
). Sin embargo, debe incluir un carácter de continuación de línea (_
) cuando especifique un calificador de miembro cuando use la palabra claveWith
. Por ejemplo:Dim customerName = customerXml. <Name>.Value Dim customerEmail = customerXml... <Email>.Value
Para obtener más información, vea Propiedades del eje XML.
Después de un signo menor que (<) o antes de un signo mayor que (
>
) al especificar un atributo . También después de un signo mayor que (>
) al especificar un atributo. Sin embargo, debe incluir un carácter de continuación de línea (_
) al especificar atributos de nivel de ensamblado o de nivel de módulo. Por ejemplo:< Serializable() > Public Class Customer Public Property Name As String Public Property Company As String Public Property Email As String End Class
Para obtener más información, consulte Información general sobre atributos.
Antes y después de los operadores de consulta (
Aggregate
,Distinct
,From
,Group By
,Group Join
,Join
,Let
,Order By
,Select
,Skip
,Skip While
,Take
,Take While
,Where
,In
,Into
,On
,Ascending
, yDescending
). No se puede dividir una línea entre las palabras clave de los operadores de consulta que se componen de varias palabras clave (Order By
,Group Join
,Take While
ySkip While
). Por ejemplo:Dim vsProcesses = From proc In Process.GetProcesses Where proc.MainWindowTitle.Contains("Visual Studio") Select proc.ProcessName, proc.Id, proc.MainWindowTitle
Para obtener más información, consulte Consultas.
Detrás de la palabra clave
In
en una instrucciónFor Each
. Por ejemplo:For Each p In vsProcesses Console.WriteLine("{0}" & vbTab & "{1}" & vbTab & "{2}", p.ProcessName, p.Id, p.MainWindowTitle) Next
Para más información, consulte Instrucción For Each...Next.
Detrás de la palabra clave
From
en un inicializador de colección. Por ejemplo:Dim days = New List(Of String) From { "Mo", "Tu", "We", "Th", "F", "Sa", "Su" }
Para obtener más información, vea Inicializadores de colección.
Adición de comentarios
El código fuente no siempre se explica por sí mismo, incluso para el programador que lo escribió. Para ayudar a documentar su código, por lo tanto, la mayoría de los programadores hacen uso liberal de los comentarios insertados. Los comentarios en el código pueden explicar un procedimiento o una instrucción determinada a cualquier persona que lea o trabaje con él más adelante. Visual Basic omite los comentarios durante la compilación y no afectan al código compilado.
Las líneas de comentario comienzan con un apóstrofo ('
) o REM
seguidos de un espacio. Se pueden agregar en cualquier parte del código, excepto dentro de una cadena. Para anexar un comentario a una instrucción, inserte un apóstrofo o REM
después de la instrucción, seguido del comentario. Los comentarios también pueden ir en su propia línea aparte. En el ejemplo siguiente se muestran estas posibilidades.
' This is a comment on a separate code line.
REM This is another comment on a separate code line.
x += a(i) * b(i) ' Add this amount to total.
MsgBox(statusMessage) REM Inform operator of status.
Comprobación de errores de compilación
Si, después de escribir una línea de código, la línea se muestra con un subrayado azul ondulado (también puede aparecer un mensaje de error), hay un error de sintaxis en la instrucción . Debe averiguar lo que está mal (buscar en la lista de tareas o mantener el puntero del mouse sobre el error y leer el mensaje de error) y corregirlo. Hasta que haya corregido todos los errores de sintaxis en el código, el programa no se compilará correctamente.
Secciones relacionadas
Término | Definición |
---|---|
operadores de asignación de | Proporciona vínculos a páginas de referencia de lenguaje que abarcan operadores de asignación como = , *= y &= . |
Operadores y expresiones | Muestra cómo combinar elementos con operadores para producir nuevos valores. |
Cómo: Interrumpir y combinar instrucciones en código | Muestra cómo dividir una sola instrucción en varias líneas y cómo colocar varias instrucciones en la misma línea. |
Procedimiento: Instrucciones de etiquetas | Muestra cómo etiquetar una línea de código. |