Главная

Популярная публикация

Научная публикация

Случайная публикация

Обратная связь

ТОР 5 статей:

Методические подходы к анализу финансового состояния предприятия

Проблема периодизации русской литературы ХХ века. Краткая характеристика второй половины ХХ века

Ценовые и неценовые факторы

Характеристика шлифовальных кругов и ее маркировка

Служебные части речи. Предлог. Союз. Частицы

КАТЕГОРИИ:






Принципы работы со сложными программными системами




Технология программирования

7 семестр

Экзаменационные вопросы

 

Принципы работы со сложными программными системами

Блочно-иерархический подход к созданию сложных систем

Практика показывает, что подавляющее большинство сложных систем как в природе,

так и в технике имеет иерархическую внутреннюю структуру. Это связано с тем, что обычно

связи элементов сложных систем различны как по типу, так и по силе, что и позволяет

рассматривать эти системы как некоторую совокупность взаимозависимых подсистем.

Внутренние связи элементов таких подсистем сильнее, чем связи между подсистемами.

Например, компьютер состоит из процессора, памяти и внешних устройств, а Солнечная система

включает Солнце и планеты, вращающиеся вокруг него.

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

на подсистемы и т.д. до самого нижнего «элементарного» уровня, причем выбор уровня,

компоненты которого следует считать элементарными, остается за исследователем. На

элементарном уровне система, как правило, состоит из немногих типов подсистем, по-

разному скомбинированных и организованных. Иерархии такого типа получили название

«целое-часть».

Поведение системы в целом обычно оказывается сложнее поведения отдельных частей,

причем из-за более сильных внутренних связей особенности системы в основном

обусловлены отношениями между ее частями, а не частями как таковыми.

В природе существует еще один вид иерархии – иерархия «простое-сложное» или

иерархия развития (усложнения) систем в процессе эволюции. В этой иерархии любая

функционирующая система является результатом развития более простой системы. Именно

данный вид иерархии реализуется механизмом наследования объектно-ориентированного

программирования.

Будучи в значительной степени отражением природных и технических систем,

программные системы обычно являются иерархическими, т. е. обладают описанными выше

свойствами. На этих свойствах иерархических систем строится блочно-иерархический подход

к их исследованию или созданию. Этот подход предполагает сначала создавать части таких

объектов (блоки, модули), а затем собирать из них сам объект.

Процесс разбиения сложного объекта на сравнительно независимые части получил

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

частями должны быть слабее, чем связи элементов внутри частей. Кроме того, чтобы из

полученных частей можно было собрать разрабатываемый объект, в процессе декомпозиции

необходимо определить все виды связей частей между собой.

При создании очень сложных объектов процесс декомпозиции выполняется

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

блоки, которые сравнительно легко разработать. Данный метод разработки получил название

пошаговой детализации.

Существенно и то, что в процессе декомпозиции стараются выделить аналогичные

блоки, которые можно было бы разрабатывать на общей основе. Таким образом, как уже

упоминалось выше, обеспечивают увеличение степени повторяемости кодов и,

соответственно, снижение стоимости разработки.

Результат декомпозиции обычно представляют в виде схемы иерархии, на нижнем

уровне которой располагают сравнительно простые блоки, а на верхнем – объект,

подлежащий разработке. На каждом иерархическом уровне описание блоков выполняют с

определенной степенью детализации, аб-страгируясъ от несущественных деталей. Следовательно, для каждого уровня

используют свои формы документации и свои модели, отражающие сущность

процессов, выполняемых каждым блоком. Так для объекта в целом, как правило,

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

должны быть специфицированы так, чтобы из них действительно можно было собрать

работающий объект. Другими словами, чем больше блок, тем более абстрактным

должно быть его описание (рис. 1.8).

При соблюдении этого принципа разработчик сохраняет возможность осмысления

проекта и, следовательно, может принимать наиболее правильные решения на каждом

этапе, что называют локальной оптимизацией (в отличие от глобальной оптимизации

характеристик объектов, которая для действительно сложных объектов не всегда

возможна).

Примечание. Следует иметь в виду, что понятие сложного объекта по мере совершенствования

технологий изменяется, и то, что было сложным вчера, не обязательно останется сложным завтра.

Итак, в основе блочно-иерархического подхода лежат декомпозиция и

иерархическое упорядочение. Важную роль играют также следующие принципы:

• непротиворечивость - контроль согласованности элементов между собой;

• полнота - контроль на присутствие лишних элементов;

• формализация – строгость методического подхода;

• повторяемость – необходимость выделения одинаковых блоков для удешевления

и ускорения разработки;

• локальная оптимизация – оптимизация в пределах уровня иерархии.

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

иерархического уровня принято называть уровнем проектирования.__






Не нашли, что искали? Воспользуйтесь поиском:

vikidalka.ru - 2015-2024 год. Все права принадлежат их авторам! Нарушение авторских прав | Нарушение персональных данных