
- •6. Обзор нотации uml
- •6.1. Диаграммы uml
- •6.2. Диаграммы прецедентов
- •6.3. Нотация uml для классов и объектов
- •6.4. Диаграммы классов
- •6.5. Диаграммы взаимодействия
- •6.6. Диаграммы состояний
- •6.7. Пакеты
- •6.8. Диаграммы параллельной кооперации
- •6.9. Диаграммы развертывания
- •6.10. Механизмы расширения uml
6.5. Диаграммы взаимодействия
В UML есть два вида диаграмм взаимодействия: диаграммы кооперации (collaboration diagram) и диаграммы последовательности (sequence diagram). Семантически они эквивалентны.
6.5.1. Диаграммы кооперации. На диаграмме кооперации показывается, как объекты динамически общаются между собой, посылая и получая сообщения. Эта диаграмма представляет структурную организацию взаимодействующих объектов, изображаемых в виде прямоугольников и соединяющих их дуг.
Помеченные стрелки рядом с дугами обозначают имя сообщения и направление его передачи между объектами. Отдельные сообщения в последовательности сообщений, отправляемых от одного объекта к другому, нумеруются. Нотация диаграмм кооперации представлена на рис.6.5. Необязательное повторение обозначается символом *, свидетельствующим, что информация посылается более одного раза. Необязательное условие означает, что сообщение посылается только тогда, когда условие истинно.
Рис. 6.5. Диаграмма кооперации в нотации UML
6.5.2. Диаграммы последовательности. Другой способ показать взаимодействие объектов – воспользоваться диаграммой последовательности (рис. 6.6). На ней обмен объектов сообщениями представлен во времени более точно и наглядно. Диаграмма последовательности двумерна: участвующие объекты изображаются вдоль горизонтальной оси, а время откладывается вдоль вертикальной. От прямоугольника каждого объекта идет вниз вертикальная пунктирная линия, называемая линией жизни. Период, в течение которого объект выполняет операцию, именуется активизацией. На протяжении этого периода линия жизни изображается двойной сплошной линией.
Актер обычно изображается в левом верхнем углу диаграммы. Помеченные горизонтальные линии представляют пересылку сообщений. Существенны только отправитель и получатель сообщения. Сообщение посылается объектом-отправителем объекту-получателю. Время возрастает в направлении сверху вниз. Расстояние по вертикали между сообщениями не имеет значения.
6.6. Диаграммы состояний
В нотации UML диаграмма перехода состояний называется диаграммой состояний. На ней состояния представляются прямоугольниками со скругленными углами, а переходы – соединяющими их дугами (рис. 6.7). Начальное состояние обозначается дугой, исходящей из маленького закрашенного кружка. Может также присутствовать необязательное конечное состояние, изображаемое закрашенным кружком внутри незакрашенного (иногда его называют «бычий глаз»). Диаграмму состояний разрешается подвергнуть иерархической декомпозиции, так что надсостояние разлагается на подсостояния.
Рядом с дугой, представляющей переход, находится условие перехода в виде: Событие [условие]/Действие. Событие вызывает переход в новое состояние. Если задано необязательное булевское условие, то переход осуществится, когда оно истинно. В результате перехода может быть выполнено необязательное действие. Дополнительно с состоянием иногда ассоциируются:
– действие при входе в состояние;
– деятельность, выполняемая во время нахождения внутри состояния;
– действие при выходе из состояния.
Рис.6.6. Диаграмма последовательности в нотации UML
Рис. 6.7. Диаграмма состояний в нотацииUML
надсостояние с последовательными подсостояниями
На рис. 6.7 показано надсостояние А, разложенное на два последовательных подсостояния – А1 и А2. В этом случае диаграмма в каждый момент времени может находиться только в одном состоянии, то есть сначала будет вход в подсостояние А1, а затем – в подсостояние А2. На рис.6.8 изображено надсостояние В, разложенное на два параллельных подсостояния – ВС и BD. Здесь объект, описываемый диаграммой, одновременно находится в каждом из подсостояний ВС и BD. Далее каждое параллельное подсостояние раскладывается на последовательные. Таким образом, вход в надсостояние В сопровождается одновременным входом в подсостояния В1 и В3.
Рис. 6.8. Нотация U ML для диаграммы состояний:
надсостояние с параллельными подсостояниями