- •Цели создания языка uml. Средства языка uml.
- •Диаграммы вариантов использования.
- •Действующее лицо (actor)
- •Описание
- •Предусловия
- •Основной и альтернативный потоки событий
- •Постусловия
- •Диаграммы взаимодействия
- •Диаграммы последовательности
- •Кооперативные диаграммы
- •Сравнение диаграмм последовательности и кооперативных диаграмм
- •Двухэтапный подход к разработке диаграмм взаимодействия
- •Диаграммы классов.
- •Общие сведения.
- •Атрибуты
- •Операции
- •Операции реализации
- •Операции управления
- •Операции доступа
- •Вспомогательные операции
- •Ассоциации
- •Зависимости
- •Агрегации
- •Обобщения
- •Множественность
- •Имена связей
- •Классы ассоциаций
- •Выявление связей
- •Диаграммы состояний
- •Деятельность
- •Входное действие
- •Выходное действие
- •События
- •Ограждающие условия
- •Действие
- •Диаграммы деятельностей
- •Диаграммы компонентов
- •Диаграммы размещения
Кооперативные диаграммы
Вторым видом диаграммы взаимодействия является кооперативная диаграмма.
Подобно диаграммам последовательности, кооперативные диаграммы (collaborations) отображают поток событий через конкретный сценарий варианта использования. Диаграммы последовательности упорядочены по времени, а кооперативные диаграммы больше внимание заостряют на связях между объектами.
Рис 5. Кооперативная диаграмма. Процесс снятия клиентом со счета 20 гривен.
Как видно из рисунка, здесь представлена вся та информация, которая была и на диаграмме последовательности, но кооперативная диаграмма по-другому описывает поток событий. Из нее легче понять отношения между объектами, но труднее понять последовательность событий. Поэтому для сценария создают диаграммы обоих типов. Они служат одной цели и содержат ту же информацию, но представляют ее с различных точек зрения.
На кооперативной диаграмме, как и на диаграмме последовательности, стрелки обозначают сообщения, обмен которыми осуществляется в рамках данного варианта использования. Их временная последовательность указывается с помощью нумерации сообщений.
Нумерация сообщений делает восприятие их последовательности более трудным, чем в случае расположения линий на странице сверху вниз, однако пространственное расположение позволяет изобразить взаимосвязь объектов.
Сравнение диаграмм последовательности и кооперативных диаграмм
В диаграмме последовательности делается акцент именно на последовательность сообщений: легче наблюдать порядок, в котором происходят различные события. На кооперативной диаграмме можно использовать пространственное расположение объектов для того, чтобы показать их статическое взаимодействие.
Принципиальным свойством любой формы диаграммы взаимодействия является её простота. Посмотрев на диаграмму, можно легко увидеть все сообщения.
Диаграммы взаимодействия наиболее хороши, когда они отображают простое поведение; при более сложном поведении они быстро теряют свою ясность и наглядность. Если нужно показать сложное поведение системы на одной диаграмме, то следует использовать диаграмму деятельностей.
Диаграммы взаимодействия следует использовать, когда нужно описать поведение нескольких объектов в рамках одного варианта использования. Они хороши для отображения взаимодействия между объектами и вовсе не так хороши для точного описания их поведения.
Если нужно описать поведение единственного объекта во многих вариантах использования, то следует применить диаграмму состояний. Если же описывается поведение во многих вариантах использования или многих параллельных процессах, следует рассмотреть диаграмму деятельностей.
Двухэтапный подход к разработке диаграмм взаимодействия
При разработке диаграмм взаимодействия применяется двухэтапный подход. Вначале изображается информация высокого уровня, которая нужна конечным пользователям проектируемой системы. Сообщения еще не соотносятся с операциями, и объекты могут быть не соотнесены с классами. Эти диаграммы позволяют аналитикам, пользователям и всем заинтересованным в бизнес-процессах увидеть, как события должны будут развиваться в системе.
Полученная на первом этапе диаграмма последовательности может выглядеть так:
Рис 6. Диаграмма последовательности, Первый этап двухэтапного подхода.
На втором этапе, после того, как пользователи пришли к согласию по поводу полученной диаграммы, можно углубиться в детали. При этом диаграмма может утратить свою полезность для пользователей, но станет очень важна для разработчиков, тестировщиков и остальных участников команды проекта.
В начале второго этапа на диаграмму помещают некоторые новые объекты. Как правило, на каждой диаграмме взаимодействия имеется управляющий объект, отвечающий за управление последовательностью событий сценария. Все диаграммы взаимодействия для некоторого варианта использования могут иметь один и тот же управляющий объект, так что у вас будет только один объект, контролирующий "все потоки информации варианта использования.
Вид диаграммы последовательности после добавления управляющего объекта:
Рис 7. Диаграмма последовательности с управляющим объектом.
Обратите внимание, что управляющий объект не реализует никаких бизнес-процессов, он просто посылает сообщения другим объектам. Управляющий объект отвечает за координацию действий других объектов и за делегирование ответственности. По этой причине такие объекты называют еще объектами-менеджерами (manager object).
Преимущество использования управляющего объекта заключается в отделении бизнес-логики от логики, определяющей последовательность событий. Если надо будет изменить последовательность, это затронет только управляющий объект.
Можно поместить на диаграмму и другие объекты, отвечающие за безопасность, обработку ошибок или за связь с базой данных. Многие из них бывают настолько общими, что допускают повторное использование во многих приложениях. Рассмотрим для примера работу с базой данных.
При сохранении информации в базе данных или при получении ее оттуда имеется две чаще всего используемые возможности. Допустим, в БД сохраняется информация о новом сотруднике - Джо Доу. Объект Джо Доу может знать о базе данных, в этом случае он сохраняет себя сам. Но он может быть полностью отделен от логики базы данных, и тогда его сохранением должен заниматься другой объект. Начнем со случая, когда Джо знает о базе данных
Рис 8. . Интеграция бизнес логики и логики баз данных
В этом примере логика приложения не отделена от логики базы данных. Объект Джо Доу занимается как первым (принятие на работу или увольнение Джо Доу), так и вторым (например, сохранение информации о Джо в базе данных и получение ее оттуда впоследствии). Поскольку множество объектов в таком приложении содержит логику базы данных, последствия любого ее изменения скажутся практически на всех этих объектах, и "эффект ряби" затронет все приложение. С другой стороны, такой подход легче моделировать и реализовывать.
Другая возможность заключается в отделении логики приложения от логики базы данных. В таком случае для работы с базой надо создать другой объект, который можно назвать менеджером транзакций (Transaction manager). Джо Доу по-прежнему содержит бизнес-логику. Объект знает, как принять на работу, уволить Джо или как повысить его по службе. Менеджер транзакций знает, как затребовать информацию о Джо из базы данных или как сохранить ее там.
Рис 9. Разделение логики приложения и логики базы данных.
Преимуществом такого подхода является возможность повторно использовать объект Джо Доу в другом приложении с другой базой данных или, вообще, без базы данных. Это также уменьшает последствия изменений в требованиях к системе. Изменения в базе данных не повлияют на логику приложения, а изменения в последней на первую. Недостаток связан с необходимостью затратить больше времени на моделирование и реализацию этого решения.
Два описанных подхода являются наиболее общими при работе с базой данных, хотя существуют и другие приемы, облегчающие этот процесс. Какое бы решение вы ни приняли, следите за тем, чтобы процесс нашел свое отражение на диаграммах Последовательности.
Помимо работы с базами данных, можно добавить в систему и другие объекты, отвечающие за обработку ошибок, проблемы безопасности или коммуникацию между процессами. Все эти детали не интересуют клиента, но неоценимы для разработчиков.
