|
[ Главная ] [ Статьи ] [ Для новичков ] [ Примеры ] [ Программы ] [ Microsoft Agent 2.0 ] [ Пособие ] [ Уроки ] [ Разное ] |
МассивыИногда бывает так нужны десятка два переменных и, если бы не массив, прищлось бы писать Dim
A As Integer
Но нет! Для этого есть массивы! Но для того, чтобы его использовать сначало надо его объявить, например: Dim A(20) As Integer Это равносильно двадцати переменным!!! Но по-моему так удобней :)? Т.е. этим мы выделили двадцать ячеек памяти. Массив представляет собой набор значений, связанных с одним именем. Массивы бывают одномерными (список значения), двумерными (таблица значений), но при необходимости работы со сложными математическими моделями, например, трёхмерными фигурами, Вы можете задать и большее количество измерений массива. Массивы могут быть так же динамический, т.е. не содержать определённое количество ячеек. Декларируются они так: Dim ABC () As ... 'т.е. в скобках ничего не указывается Чтобы установить размерность массива нужно использовать ключевое слово ReDim, которое перераспределяет массив, стирая старые ячейки. Если Вам нужно перераспределить массив, оставив старые ячейки надо использовать ключевое слово Preserve. Например, у Вас есть восемь чисел и для каждого нужна переменная. Если они одинакового типа, то можно создать массив и присвоить эти значения (см. примечания): Dim ABC (8) As Integer ABC(0)
= 123
Этот
массив графически можно представить так:
Допустим, что Вы пишите программу, которая создаёт палитры и она должна запросить количество цветов, которые она должна смешать и какие (Вы только сильно не радуйтесь следующий пример ничего мешать не будет, он только запросит цвета ;-)): Sub
Main()
'перераспределяем
в массиве столько ячеек, сколько цветов мы получили
'запускаем
цикл, который должен повториться столько раз сколько всего
'запускаем
цикл, который собирает все цвета в одну переменную
MsgBox Msg 'выводим все цвета, которые ввели End Sub Здесь вроде бы всё просто! Теперь двумерный массив. Но не пугайтесь, здесь не менее просто, только с непривычки можно чуть-чуть запутаться :-). Декларируются они так: Dim ABC(1, 8) As String Это
получается этакая таблица: две ячейки на десять. Примерно так:
ABC(0, 0) = "красный"
и т.д. Ну, очень напоминает систему координат! А чтобы вызвать, например, лиловый нужно написать так: 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. Также есть другой способ: |
|
|
|
>>>Если у вас есть статья которой нет на сайте
пришлите ее мне--------> Послать статью >>>Если вы хотите задать вопрос пишите--------> Мне нужна помощь |
|
|
|