Массивы

Иногда бывает так нужны десятка два переменных и, если бы не массив, прищлось бы писать

Dim A As Integer

Dim B As Integer

…….

…….

…….

Dim X As Integer

Dim Y As Integer

Но нет! Для этого есть массивы! Но для того, чтобы его использовать сначало надо его объявить, например:

Dim A(20) As Integer

Это равносильно двадцати переменным!!! Но по-моему так удобней :)? Т. е. этим мы выделили двадцать ячеек памяти.

Массив представляет собой набор значений, связанных с одним именем. Массивы бывают одномерными (список значения), двумерными (таблица значений), но при необходимости работы со сложными математическими моделями, например, трехмерными фигурами, Вы можете задать и большее количество измерений массива. Массивы могут быть так же динамический, т. е. не содержать определенное количество ячеек. Декларируются они так:

Dim ABC () As… т. е. в скобках ничего не указывается

Чтобы установить размерность массива нужно использовать ключевое слово ReDim, которое перераспределяет массив, стирая старые ячейки.

Если Вам нужно перераспределить массив, оставив старые ячейки надо использовать ключевое слово Preserve.

Например, у Вас есть восемь чисел и для каждого нужна переменная. Если они одинакового типа, то можно создать массив и присвоить эти значения ( см. примечания):

Dim ABC (8) As Integer

ABC(0) = 123

ABC(1) = 5

ABC(2) = 87

ABC(3) = 4

ABC(4) = 99

ABC(5) = 43

ABC(6) = 7

ABC(7) = 21

ABC(8) = 11

Этот массив графически можно представить так:

Ячейка012345678
Значение1235874994372111

Допустим, что Вы пишите программу, которая создает палитры и она должна запросить количество цветов, которые она должна смешать и какие (Вы только сильно не радуйтесь следующий пример ничего мешать не будет, он только запросит цвета ;-)):

Sub Main()

Dim MyArray() As Stringобъявляем массив, содержащий цвета

Dim x As Integer объявляем переменную, содержащую кол-во цветов

Dim y As Integer объявляем переменную-счетчик

Dim Msg As String объявляем переменную, содержащую все названия цветов

X = InputBox(“Введите число цветов”) получаем количество цветов

Перераспределяем в массиве столько ячеек, сколько цветов мы получили

ReDim MyArray(x)

Запускаем цикл, который должен повториться столько раз сколько всего

Цветов

For y = 1 To x

присваеваем каждой ячейке цвет

MyArray(y) = InputBox(“Ведите цвет номер ” &; y)

Next

Запускаем цикл, который собирает все цвета в одну переменную

For y = 1 To x

теперь мы вытаскиваем все значения

Msg = Msg + MyArray(y) + Chr(13) + Chr(10)

Next

MsgBox Msg выводим все цвета, которые ввели

End Sub

Здесь вроде бы все просто! Теперь двумерный массив. Но не пугайтесь, здесь не менее просто, только с непривычки можно чуть-чуть запутаться :-).

Декларируются они так:

Dim ABC(1, 8) As String

Это получается этакая таблица: две ячейки на десять. Примерно так:

012345678
0КрасныйОранжевыйЖелтыйЗеленыйГолубойСинийФиолетовыйБирюзовыйПурпурный
1КоричневыйСерыйЧерныйБелыйРозовыйЛиловыйВишневыйПрозрачныйМатовый

И все это присвоить таким образом:

ABC(0, 0) = “красный”

ABC(0, 1) = “оранжевый”

ABC(0, 2) = “желтый”

И т. д. Ну, очень напоминает систему координат! А чтобы вызвать, например, лиловый нужно написать так:

Color = ABC(1, 5) переменной color присваеваем строку “лиловый”

Трехмерную таблицу я начертить не смогу, но думаю, что и там все понятно. Объявляется он, например так:

Dim ABC (10, 4, 7)

Таким образом уже создется как бы геометрический прямоугольник длиной 10, шириной – 4 и высотой – 7. Всего внутри 440 ячеек ( 11 * 5 * 8).

Примечание: Вы должны помнить, что объявляя массив с, например, тремя ячейками, в скобках Вы должны писать 2,

Dim ABC(2) As Variant

Т. к. идекс ячеек начинается с нуля: 0, 1, 2 – в сумме получается три. Если в скобках окажется цифра три, то ячеек будет четыре: 0, 1, 2, 3. Если Вам кажется это неудобным, то строкой (в самом верху формы или модуля):

Option Base 1

Вы как бы сдвините массив вверх на один, и нижней границей станет не 0, а 1. Также есть другой способ:

Dim ABC(1 To 2)

Результат одинаков!


Массивы