Instrucción Dim
Instrucción Dim
Instrucción Dim
[ <attributelist> ] [ accessmodifier ]
[[ Shared ] [ Shadows ] | [ Static ]] [ ReadOnly ]
Dim [ WithEvents ] variablelist
Elementos
Trmino Definicin
Public
Protected
accessmodifier Friend
Private
Protected Friend
Opcional. Especifica que stas son variables de objeto que hacen referencia
WithEvents
a instancias de una clase que puede provocar eventos. Vea WithEvents.
Parte Descripcin
variablename Requerido. Nombre de la variable. Vea Nombres de
variablelist elementos declarados (Visual Basic).
boundslist Opcional. Lista de lmites de cada dimensin de una variable de
matriz.
New Opcional. Crea una nueva instancia de la clase cuando se ejecuta la
instruccin Dim.
datatype Opcional. Tipo de datos de la variable.
With Opcional. Incluye la lista de inicializadores de objeto.
propertyname Opcional. Nombre de una propiedad en la clase de la que se
est creando una instancia.
propinitializer Se requiere despus de propertyname =. Expresin que se
evala y se asigna al nombre de propiedad.
initializer Opcional si no se especifica New. Expresin que se evala y se
asigna a la variable cuando se crea.
Comentarios
El compilador de Visual Basic utiliza la instruccin Dim para determinar el tipo de datos de
la variable y otra informacin, como por ejemplo qu cdigo puede obtener acceso a la
variable. En el ejemplo siguiente se declara una variable que contiene un valor Integer.
VB
Dim numberOfStudents As Integer
Puede especificar cualquier tipo de datos o el nombre de una enumeracin, estructura, clase
o interfaz.
VB
Dim finished As Boolean
Dim monitorBox As System.Windows.Forms.Form
En un tipo de referencia, la palabra clave New se utiliza para crear una nueva instancia de
la clase o estructura especificada por el tipo de dato. Si utiliza New, no utilice una
expresin de inicializador. En su lugar, si son necesarios, proporcione argumentos al
constructor de la clase a partir de la que est creando la variable.
VB
Dim bottomLabel As New System.Windows.Forms.Label
Una variable que se declara en el nivel de mdulo, fuera de cualquier procedimiento, es una
variable miembro o campo. Las variables miembro estn en mbito a lo largo de su clase,
estructura o mdulo. Una variable que se declara dentro de un procedimiento es una
variable local. Las variables locales slo estn en mbito dentro de su procedimiento o
bloque.
La palabra clave Dim es opcional y se suele omitir si especifica cualquiera de los siguientes
modificadores: PublicProtected, Friend, Protected Friend, Private, Shared, Shadows, Static,
ReadOnly o WithEvents.
VB
Public maximumAllowed As Double
Protected Friend currentUserName As String
Private salary As Decimal
Static runningTotal As Integer
VB
Dim quantity As Integer = 10
Dim message As String = "Just started"
VB
' Use explicit typing.
Dim num1 As Integer = 3
Para obtener informacin acerca de lo que sucede cuando un tipo de datos o inicializador
no se especifica, consulte Valores y tipos de datos predeterminados ms adelante en este
tema.
Puede utilizar un inicializador de objeto para declarar instancias de tipos annimos y con
nombre. El cdigo siguiente crea una instancia de una clase Student y utiliza a un
inicializador de objeto para inicializar las propiedades.
VB
Dim student1 As New Student With {.First = "Michael",
.Last = "Tucker"}
Para obtener ms informacin sobre los inicializadores de objeto, vea Cmo: Declarar un
objeto usando un inicializador de objeto (Visual Basic), Inicializadores de objeto: Tipos con
nombre y annimos (Visual Basic) y Tipos annimos (Visual Basic).
VB
Dim lastTime, nextTime, allTimes() As Date
Si declara ms de una variable con una clusula As, no puede proporcionar un inicializador
para ese grupo de variables.
Se pueden especificar tipos de datos diferentes para variables diferentes utilizando una
clusula As independiente para cada variable declarada. Todas las variables toman el tipo
de datos especificado en la primera clusula As que se encuentre despus de su parte
variablename correspondiente.
VB
Dim a, b, c As Single, x, y As Double, i As Integer
' a, b, and c are all Single; x and y are both Double
Matrices
Puede declarar una variable para contener una matriz, que puede almacenar varios valores.
Para especificar que una variable contiene una matriz, incluya un parntesis
inmediatamente despus de variablename. Para obtener ms informacin sobre las matrices,
vea Matrices en Visual Basic.
Se puede especificar el lmite inferior y superior de cada dimensin de una matriz. Para
ello, incluya boundslist dentro de los parntesis. En cada dimensin, boundslist especifica
el lmite superior y, opcionalmente, el lmite inferior. El lmite inferior siempre es cero,
tanto si se especifica como si no. Cada ndice puede variar de cero hasta el valor de su
lmite superior.
Las dos instrucciones siguientes son equivalentes. Cada instruccin declara una matriz de
21 elementos Integer. Cuando se tiene acceso a la matriz, el ndice puede variar de 0 a 20.
VB
Dim totals(20) As Integer
Dim totals(0 To 20) As Integer
La instruccin siguiente declara una matriz bidimensional de tipo Double. La matriz tiene 4
filas (3 + 1) de 6 columnas (5 + 1) cada una. Observe que el lmite superior representa el
valor ms alto posible del ndice, no la longitud de la dimensin. La longitud de la
dimensin es el lmite superior ms uno.
VB
Dim matrix2(3, 5) As Double
Todos los lmites de una declaracin de matriz se pueden dejar en blanco. En este caso, la
matriz tiene el nmero de dimensiones que especifica, pero se no se inicializa. Tiene el
valor Nothing hasta que se inicialicen por lo menos algunos de sus elementos. La
instruccin Dim debe especificar los lmites para todas las dimensiones o para ninguna de
ellas.
VB
' Declare an array with blank array bounds.
Dim messages() As String
' Initialize the array.
ReDim messages(4)
Si la matriz tiene ms de una dimensin, debe incluir comas entre los parntesis para
indicar el nmero de dimensiones.
VB
Dim oneDimension(), twoDimensions(,), threeDimensions(,,) As Byte
Puede declarar una matriz de longitud cero declarando una de las dimensiones de la matriz
para que sea -1. Un variable que contiene una matriz de longitud cero no tiene el valor
Nothing. Ciertas funciones de Common Language Runtime requieren matrices de longitud
cero. Si se intenta acceder a dicha matriz, se produce una excepcin de tiempo de
ejecucin. Para obtener ms informacin, vea Matrices en Visual Basic.
Puede inicializar los valores de una matriz utilizando un literal de matriz. Para ello, encierre
los valores de inicializacin entre llaves ({}).
VB
Dim longArray() As Long = {0, 1, 2, 3}
VB
Dim twoDimensions(,) As Integer = {{0, 1, 2}, {10, 11, 12}}
Para obtener ms informacin sobre los literales de matriz, vea Matrices en Visual Basic.
Char Binario 0
Todas las referencias de tipo (incluidas Object,
Nothing
String y todas las matrices).
Boolean False
Cada elemento de una estructura se inicializa como si fuera una variable independiente. Si
se declara la longitud de una matriz pero no se inicializan sus elementos, stos se inicializan
como si fueran una variable independiente.
Una variable local Static tiene un perodo de duracin ms largo que el del procedimiento
en el que se declara. Los lmites de la duracin de la variable dependen de dnde se declare
el procedimiento y si es Shared.
Declaracin de
La variable se inicializa La variable deja de existir
procedimiento
En una clase o
La primera vez que se llama al Cuando la instancia se
estructura, el
procedimiento en una instancia libera para la recoleccin
procedimiento no es
especfica de elementos no utilizados
Shared
Atributos y modificadores
Slo se pueden aplicar atributos a las variables miembro, no a las variables locales. Un
atributo proporciona informacin a los metadatos del ensamblado, que no son significativos
para el almacenamiento temporal como las variables locales.
Nota
El cdigo externo a una clase, estructura o mdulo debe calificar el nombre de una variable
miembro con el nombre de esa clase, estructura o mdulo. El cdigo externo a un
procedimiento o bloque no puede hacer referencia a ninguna variable local dentro de ese
procedimiento o bloque.
Si una clase consume un recurso determinado valioso y suficiente (como una conexin de
base de datos o un identificador de archivos), puede que no desee esperar hasta la siguiente
recoleccin de elementos no utilizados para limpiar una instancia de clase que ya no se
utiliza. Una clase puede implementar la interfaz IDisposable para proporcionar una manera
de liberar recursos antes de una recoleccin de elementos no utilizados. Una clase que
implementa expone de esa interfaz un mtodo Dispose que se puede llamar para obligar a
los recursos valiosos que se producirn liberar inmediatamente.
Ejemplo
VB
' Declare and initialize a Long variable.
Dim startingAmount As Long = 500
El ejemplo siguiente muestra los nmeros primos entre 1 y 30. El mbito de las variables
locales se describe en comentarios de cdigo.
VB
Public Sub ListPrimes()
' The sb variable can be accessed only
' within the ListPrimes procedure.
Dim sb As New System.Text.StringBuilder()
Debug.WriteLine(sb.ToString)
' Output: 2 3 5 7 11 13 17 19 23 29
End Sub
Return True
End If
End Function
VB
' Create a new instance of a Car.
Dim theCar As New Car()
theCar.Accelerate(30)
theCar.Accelerate(20)
theCar.Accelerate(-5)
Debug.WriteLine(theCar.Speed.ToString)
' Output: 45
VB
Public Class Car
' The speedValue variable can be accessed by
' any procedure in the Car class.
Private speedValue As Integer = 0