Похожие презентации:
Диаграмма компонентов
1. UML-диаграммы
Диаграмма компонентовUML-диаграммы
2. Диаграмма компонентов
Диаграмма компонентов (Component Diagram) – это диаграмма , которая служитдля представления программных компонентов и зависимостей между ними.
Диаграмма компонентов разрабатывается для следующих целей:
– Визуализация общей структуры ПО.
– Спецификация исполняемого кода (единиц развертывания) ПО.
– Обеспечение многократного использования отдельных фрагментов кода ПО.
– Представление концептуальной и физической схем баз данных.
Имя компонента записывается аналогично имени линии жизни на диаграмме
последовательности в следующем формате (БНФ):
<имя-компонента>::=[<собственное-имя-компонента>] [‘:’<имя-типа>],
при этом собственное имя компонента записывается со строчной буквы и в имени
компонента должен присутствовать хотя бы один терм.
Пример изображения простого компонента и компонента с интерфейсами:
IDialog
«component»
Заказ
ISe ns or
IApplication
«component»
Контролле р
2
3. Диаграмма компонентов
Пример представления компонентов и интерфейсов:Заказываемый
Товар
«component»
Товар
Заказываемый
Товар
Сопровождение
Товара
«component»
Заказ
ПолучательТовара
ЗаголовокЗаказа
заказ
элемент
Местонахождение
Товара
1
*
СтрокаТовара
Счет-фактура
Представление интерфейсов в форме классификаторов с отношениями зависимости
и реализации:
«interf ace»
Заказывае мый
Товар
найтиПоИ мени()
задат ьКоличест в о()
получит ьДет али()
«use»
«component»
Заказ
«interf ace»
М е стонахож де ние Товара
задат ь()
изменит ь()
получит ьДет али()
3
4. Диаграмма компонентов
Порт определяет различимую точку взаимодействия между компонентом иокружающей средой или между компонентом и его внутренними частями.
Наличие имени у порта не является обязательным. При отсутствии имени порта его
тип ассоциируется с типом интерфейса, с которым связан порт.
Заказываемый
Товар
«component»
Заказ
ПолучательТовара
ЗаголовокЗаказа
Сопровождение
Товара
заказ
элемент
1
Местонахождение
Товара
*
СтрокаТовара
4
5. Диаграмма компонентов
Собирающий соединитель связывает два компонента в контексте требуемых ипредоставляемых интерфейсов:
Сопровождение
Товара
Сопровождение
Товара
«component»
Заказ
ЗаказываемыйТовар
«component»
:Заказ
ЗаказываемыйТовар
ЗаказываемыйТовар
ЗаказываемыйТовар
«component»
Товар
«component»
:Товар
5
6. Диаграмма компонентов
Пример диаграммы компонентов с собирающими соединителями для одинаковыхинтерфейсов:
:Отме не нныйЗаказ
М е стонахож де ние
М е стополож е ние
Товара
:Склад
Клиент
Клиент
Че лове к
:Заказ
:Физическое
Лицо
М е стополож е ние
Организация
Сопровож де ниеЗаказывае мый
:Поставщик
:Компания
Товар
Заказывае мый
Сопровож де ние
Товар
:Се рвис
:Товар
6
7. Диаграмма компонентов
Делегирующий соединитель связывает контракт компонента (интерфейсы) свнутренними частями этого компонента.
Делегирующий соединитель выполняет одну из следующих задач:
– Передача сообщений или сигналов, поступающих в порт компонента извне, для
обработки в некоторую внутреннюю часть компонента или другой порт.
– Передача сообщений или сигналов, поступающих из некоторой внутренней
части компонента, для обработки во внешний порт компонента.
Местонахождение
Товара
«component»
Заказ
:ЗаголовокЗаказа
ПолучательТовара
:СтрокаТовара
7
8. Диаграмма компонентов
Пример представления внутренней структуры компонента:М е стонахож дение
Товара
«component»
:М агазин
«delegate»
М е стонахож дение
Товара
«component»
:Заказ
Клиент
Клиент
«component»
:Физиче ское
Лицо
Сче т
Заказывае мый
Товар
Заказывае мый
Товар
«delegate»
Сче т
«component»
:Товар
8
9. Диаграмма компонентов
Пример отношений зависимости между компонентами с интерфейсами:Местонахождение
Товара
Человек
Получатель
Товара
Физическое
Лицо
Заказ
Местоположение
Сопровождение
Товара
Заказываемый
Товар
Поставщик
Сопровождение
Сервис
Организация
Компания
Заказываемый
Товар
Товар
Обратите внимание: стрелка «отношения зависимости» направлена от «требуемого
интерфейса» к «предоставляемому интерфейсу»
9
10. Диаграмма компонентов
Пример отношений зависимости между компонентами:Отме не нныйЗаказ
Физиче ское
Лицо
Склад
Заказ
Поставщик
Компания
Се рвис
Товар
10
11. Диаграмма компонентов
Отношение реализации есть отношение зависимости для связи компонентов с темиклассификаторами, которые реализуют функциональность данного компонента.
Реализация компонента может быть дополнительно помечена стереотипом
«implement».
«component»
Заказ
<<implement>>
Заголовок
Заказа
<<implement>>
Строка
Товара
11
12. Диаграмма компонентов
Примеры нотаций для компонентов специального видаDialog.dll
Inde x.htm l
Conte xt .hlp
M ain.cpp
12
13. Диаграмма компонентов
<<se rve r page >><<client page>>
Компонент Серверная страница представляет Webстраницу на стороне сервера, содержащую
выполняемые сервером сценарии.
Эти сценарии могут взаимодействовать с
серверными ресурсами, такими как базы данных,
бизнес-логика и внешние системы.
Операции классов, которые реализуют данный
компонент – это функции сценария, а их атрибуты переменные, видимые в пределах этой страницы.
Компонент Клиентская страница представляет
Web-страницу в формате HTML, а также данные,
элементы интерфейса и даже бизнес-логику.
Клиентские страницы отображаются браузерами и
могут содержать сценарии, которые
интерпретируются браузером.
Операции клиентской страницы могут
соответствовать функциям, содержащимся в
дескрипторах сценария страницы.
Атрибутам клиентской страницы соответствуют
объявленные в дескрипторах сценария переменные,
которые доступны любой функции в пределах
данной страницы.
13
14. Диаграмма компонентов
<<form >><<fram e s e t>>
Компонент Форма есть набор полей ввода и
представляет собой часть клиентской страницы.
Форма преобразуется непосредственно в дескриптор
HTML <form>.
Атрибуты формы могут представлять поля ввода,
текстовые поля, переключатели, флажки, скрытые
поля формы HTML.
С формой не связано никаких операций, поскольку их
нельзя в ней инкапсулировать.
Любые операции взаимодействия с формой являются
свойствами содержащей ее страницы.
Компонент Набор фреймов - это контейнер,
состоящий из нескольких Web-страниц.
Любую прямоугольную область web-страницы можно
разделить на несколько фреймов.
Каждый фрейм может быть связан с компонентом
«Цель», однако это необязательно.
Содержимым фрейма может быть Web-страница или
другой фрейм. Набор фреймов преобразуется
непосредственно в набор фреймов Web-страницы и
дескриптор HTML <frame>.
14
15. Диаграмма компонентов
<<targe t>><<w eb-page >>
Компонент Цель представляет собой именованную
область окна браузера, в которой могут отображаться
Web-страницы.
Имя цели соответствует имени целевого объекта.
Обычно целью является один из фреймов набора.
Однако целью может быть и новое окно браузера. Для
цели может быть задано место назначения, где будет
отображена новая Web-страница.
Имя цели должно быть уникальным для каждого клиента
системы.
Компонент Web-страница представляет такую Webстраницу, которую браузер может запрашивать по её
имени. Этот компонент при необходимости может
содержать клиентские или серверные сценарии.
Обычно web-страницы являются текстовыми файлами,
доступ к которым можно получить через Web-сервер.
Однако они могут быть также компилируемыми модулями,
загружаемыми и запускаемыми Web-сервером.
В любом случае, при доступе к такой странице, она
генерирует документ в формате HTML, который
отправляется в ответ на запрос браузера.
15
16. Диаграмма компонентов
<<java s e rve rpage >>
<<s e r vle t>>
Компонент JSP (Java Server Page) представляет Webстраницы, реализующие код JSP серверной части
приложения. Этот стереотип применим лишь к
приложениям, в которых используется технология Java
Server Pages.
Этот компонент представляет сервлет Java. Стереотип
применим лишь к приложениям, поддерживающим
сервлеты компании Sun.
Компонент Servlet представляет сервлет Java.
Стереотип применим лишь к приложениям,
поддерживающим сервлеты компании Sun.
16