Массивы
В заключение этой дискуссии полезно рассмотреть пример контейнерного класса
Массивы как объекты
Понятие массив обычно является частью определения языка программирования. В объектной технологии нет необходимости нагружать нотацию специальными заранее определенными конструкциями: массив - контейнерный объект, экземпляр класса, который можно назвать
indexing
description: 'Последовательность значений одного типа или согласуемых типов, %
%доступных через целые индексы в заданном диапазоне'
class ARRAY [G] creation
make
feature
make (minindex, maxindex: INTEGER) is
-- Размещение массива с границами minindex и maxindex
-- (пустой, если minindex > maxindex)
do ... end
lower, upper, count: INTEGER
-- Минимальный и максимальный допустимый индекс; размер массива.
put (v: G; i: INTEGER) is
-- Присвоить v элементу массива с индексом i
do ... end
infix '@', item (i: INTEGER): G is
-- Элемент с индексом i
do ... end
end -- класса ARRAY
Для создания массива
create a.make (m, n)
Для задания значений элементов массива используется процедура
x := a.item (i)
Вот схема того, как этот класс может быть использован клиентом:
pa: ARRAY [POINT]; p1: POINT; i, j: INTEGER
...
create pa.make (-32, 101) -- Разместить массив с указанными границами.
pa.put (p1, i) -- Присвоить значение p1 элементу с индексом i.
...
p1 := pa.item (j) -- Присвоить сущности p1 значение элемента с индексом j.
В обычной нотации (скажем, в Pascal) нужно писать:
Свойства массива
Некоторые замечания о классе.
[x]. Подобные классы существуют для массивов большей размерности:
[x]. Компонент
[x]. Техника утверждений позволяет связывать точные условия согласования с
[x]. Идея описания массивов как объектов (и
[x]. Так как
Как только мы изучим механизм утверждений, этот унифицированный подход даст возможность развития нашего класса. Предусловия позволят управлять проверкой корректного задания индексов, что обычно требует узко специализированных механизмов.
