Сущность-контроль-граница - Entity-control-boundary
В объект-контроль-граница (ЕЦБ), или же объект-граница-контроль (EBC), или же пограничный контрольный объект (До н.э.) является архитектурный образец используется в вариант использования ведомый объектно-ориентированное проектирование программного обеспечения который структурирует классы, составляющие программного обеспечения в соответствии со своими обязанностями при реализации варианта использования.
Происхождение и эволюция
Подход Entity-Control-Boundary берет свое начало вИвар Якобсон на основе сценария использования OOSE метод опубликован в 1992 г.[1],.[2] Первоначально он назывался Entity-Interface-Control (EIC), но очень быстро термин "граница" заменены "интерфейс"во избежание путаницы с объектно-ориентированный язык программирования терминология.
Дальнейшее развитие он получил в Единый процесс, который способствует использованию ECB в деятельности по анализу и проектированию при поддержке Стереотипы UML.[3] Гибкое моделирование,[4][5] и ICONIX процесс[6] разработан на основе архитектурного шаблона ECB с диаграммами устойчивости.[7]
Принцип
Шаблон ECB организует обязанности классов в соответствии с их ролью в реализации варианта использования:
- сущность представляет собой долгоживущую информацию, актуальную для заинтересованных сторон (т. е. в основном полученную из объектов предметной области, обычно постоянную);
- граница инкапсулирует взаимодействие с внешними участниками (пользователями или внешними системами);
- элемент управления обеспечивает обработку, необходимую для выполнения варианта использования и его бизнес-логики, а также координирует, последовательности элементов управления другими объектами, участвующими в прецеденте.
Соответствующие классы затем группируются в пакеты услуг, которые представляют собой неделимый набор связанных классов, которые можно использовать в качестве единиц доставки программного обеспечения.
Классы ECB впервые идентифицируются, когда сценарии использования анализируются:
- каждый вариант использования представлен как класс управления;
- каждое различное отношение между вариантом использования и действующим лицом представлено как граничный класс;
- сущности получены из описания варианта использования.
Затем классы уточняются и реструктурируются или реорганизуются по мере необходимости для дизайна, например:
- Выделение общего поведения в различных элементах управления прецедентами
- Определение центрального граничного класса для каждого типа человека-актора и для каждой внешней системы, который обеспечит согласованный интерфейс с внешним миром.
Шаблон ECB предполагает, что обязанности классов также отражаются в отношениях и взаимодействиях между различными категориями классов, чтобы обеспечить надежность дизайна.[8],.[9]
Диаграмма устойчивости
Диаграммы устойчивости позволяют визуально представить отношения между сущностями, элементами управления, границами и участниками.[4] Он использует графические стереотипы, представленные в ранних работах Якобсона:
Представление | Отношения с | ||||
---|---|---|---|---|---|
Роль | Символ | Актер | Граница | Контроль | Юридическое лицо |
Актер | да | да | Нет | Нет | |
Граница | да | Часть / целое | да | Нет | |
Контроль | Нет | да | да | да | |
Юридическое лицо | Нет | Нет | да | да |
Применяются следующие ограничения надежности:
- Актеры могут знать только границы и общаться с ними
- Границы могут связываться только с участниками и элементами управления.
- Органы управления могут знать границы и объекты и взаимодействовать с ними, а при необходимости и с другими элементами управления.
- Организации могут знать только о других организациях, но могут также связываться с органами управления;
В принципе, организации не должны знать о границах и средствах контроля. Однако на практике некоторые варианты позволяют объектам, границам и элементам управления подписываться на объект в качестве наблюдателя.
Точно так же ограничение граничного класса, не знающего о других граничных классах, применяется только на самом высоком уровне, а не между классами, которые взаимодействуют для реализации одной и той же границы.
Отношение к другим архитектурным образцам
Есть некоторое сходство между ЕЦБ и Модель-представление-контроллер (MVC): сущности принадлежат модели, а представления принадлежат границам. Однако роль ECB-элемента управления сильно отличается от MVC-контроллера, поскольку он инкапсулирует также бизнес-логику сценария использования, тогда как контроллер MVC обрабатывает пользовательский ввод, за который в ECB отвечает граница. Контроль ЕЦБ увеличивается разделение проблем в архитектура путем инкапсуляции бизнес-логики, которая напрямую не связана с сущностью.[2]
ECB можно использовать вместе с шестиугольная архитектура, всякий раз, когда границы образуют внешний слой адаптера.[10]
ECB совместим с чистой архитектурой, которая объединяет принципы ECB с другими парадигмами архитектурного проектирования.[11][12] Чистая архитектура помещает объекты в ядро и окружает их кольцом вариантов использования (то есть управлением ECB) и кольцом со шлюзами и презентаторами (то есть границами ECB). Однако чистая архитектура требует односторонней зависимости извне внутрь, что требует разделения элементов управления ECB на логику вариантов использования и координацию объектов.
Смотрите также
Примечания и ссылки
- ^ Якобсон, Ивар. (1992). Объектно-ориентированная разработка программного обеспечения: подход на основе вариантов использования. [Нью-Йорк]: ACM Press. стр.130–133. ISBN 0201544350. OCLC 26132801.
- ^ а б "Информация о прочтении объектно-ориентированной разработки программного обеспечения, Ивар Якобсон и др. (1992)". tedfelix.com. Получено 2019-08-14.
- ^ Единый процесс разработки программного обеспечения. Джейкобсон, Ивар., Буч, Грейди., Рамбо, Джим. Ридинг, Массачусетс: Эддисон-Уэсли. 1999. С. 44, 183–188, 202–205, 256–257, 439. ISBN 0201571692. OCLC 636807532.CS1 maint: другие (связь)
- ^ а б Скотт Эмблер. «Диаграммы устойчивости: введение в Agile». agilemodeling.com. Получено 2019-08-14.
- ^ Эмблер, Скотт В., 1966- (2004). Учебник по объектам: разработка на основе гибкого моделирования с использованием UML 2.0 (3-е изд.). Кембридж, Великобритания: Издательство Кембриджского университета. ISBN 0521540186. OCLC 54081540.CS1 maint: несколько имен: список авторов (связь)
- ^ «Устранение разрыва между анализом и дизайном • Регистр». www.theregister.co.uk. Получено 2019-08-14.
- ^ Дугердил, Филипп (2013). «Архитектура мобильного корпоративного приложения: подход к моделированию для адаптации корпоративных приложений к мобильным устройствам». Материалы семинара ACM 2013 по жизненному циклу мобильной разработки - MobileDeLi '13. Индианаполис, Индиана, США: ACM Press: 9–14. Дои:10.1145/2542128.2542131. ISBN 9781450326032.
- ^ "Рекомендация: шаблон" сущность-контроль-граница ". posomas.isse.de. Получено 2019-08-14.
- ^ Дашнер, Себастьян (2017). Архитектура современных приложений Java EE: проектирование легких бизнес-ориентированных корпоративных приложений в эпоху облаков, контейнеров и Java EE 8. Packt Publishing. стр. раздел «Граница контроля за организацией». ISBN 9781788397124. OCLC 1008993521.
- ^ "Паттерн" сущность-контроль-граница ". www.cs.sjsu.edu. Получено 2019-08-14.
- ^ Мартин, Роберт, К. (2012-08-12). "Чистая архитектура | Блог чистого кодера". blog.cleancoder.com. Получено 2019-08-12.
- ^ Мартин, Роберт С. (2017). Чистая архитектура: руководство по структуре и дизайну программного обеспечения. Прентис Холл. ISBN 978-0-13-449416-6. OCLC 1004983973.