Fixed Size

Fixed arrays have a fixed size which cannot be changed at run-time.
These are also known as Static Arrays.
An array is declared by including parentheses after the array name or identifier.
An integer is placed within the parentheses, defining the number of elements in the array.


Fixed Array - Integer Data Type Array

You can declare a fixed array using the Dim statement.
It is good practice to always declare your arrays with an explicit data type.
This line creates an array of Integers with 4 items.
All VBA arrays (by default) start at zero.

Dim myArray(3) As Integer 

Debug.Print myArray(0) '= 0
Debug.Print myArray(1) '= 0
Debug.Print myArray(2) '= 0
Debug.Print myArray(3) '= 0

Fixed Array - Variant Data Type Array

This line creates an array of Variant with 4 items.

Dim myArray(3) As Variant 

Debug.Print myArray(0) '= Empty
Debug.Print myArray(1) '= Empty
Debug.Print myArray(2) '= Empty
Debug.Print myArray(3) '= Empty

Fixed Array - Variant Data Type

You can declare a fixed array as a single variant data type and then use the ARRAY function.
This function declares and adds the values in one statement.

Dim avNumbers As Variant 
avNumbers = Array(10,20,30)

An array created with a single variant data type will always create an array of Variants.


Default Values

After declaring an array it will contain default values.
Numeric arrays will contain the number 0.
String arrays will contain the Empty String "".
Variant arrays will contain the Empty keyword.
Object arrays will contain the Nothing keyword.


Explicit Lower Bound

It is possible to explicitly declare the lower bound of your fixed array.
The following two lines are equivalent and both these arrays contain 101 elements.
The index values range from 0 to 100.

Dim myArray(100) As Integer 
Dim myArray(0 To 100) As Integer

If you wanted to declare an array containing exactly 100 elements you could do this in a number of different ways.

Dim myArray(99) As Integer 
Dim myArray(0 To 99) As Integer
Dim myArray(1 To 100) As Integer

The first two lines are equivalent. The first element is myArray(0) and the last element is myArray(99).
The last line has slightly different index numbers. The first element is myArray(1) and the last element is myArray(100).
In fact you could define the index numbers to be any range you like as long as the first number is less than the second number.

Dim myArray(101 To 200) As Integer 
Dim myArray(-49 To 50) As Integer

When you explicitly declare the lower bound of your array this will override the Option Base statement.


Never Use Option Base 1

If you want all your arrays to start at the index number 1 (instead of 0) you can explicitly declare the lower bound to be 1.
More details can be found on the Option Base 1 page.
The following line of code will declare an array containing exactly 100 elements with the index values from 1 to 100.

Dim myArray(1 To 100) As Integer 

Important

For more details about using Excel Ranges with arrays, refer to the Cells & Ranges > Working with Arrays page.


© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext