Переходим теперь к процессу проектирования и разработки ПС. Главная цель процесса проектирования и разработки состоит в создании программного продукта, обладающего высоким качеством, в приемлемые сроки в рамках прогнозируемого бюджета. Это означает, что качество и сроки разработки ПС должны удовлетворять заказчика. Достичь этого можно только при правильной организации работ по созданию ПС.
Предваряя последующее изложение, следует сделать одно замечание относительно употребления однокоренных слов "методология", "метод" и "методика". Методологией будем называть совокупность механизмов, применяемых при разработке программных систем и объединенных единым философским подходом. В этом цикле статей мы рассматриваем ОО методологию. Методом будем называть совокупность, включающую концептуальные понятия, базовую нотацию, описывающую графическое представление этих понятий и правила построения моделей, а также описание процесса проектирования и разработки. Наконец, термином "методика" мы будем пользоваться для обозначения достаточно подробного описания последовательности шагов, выполняемых при разработке проекта системы на основе определенного метода. Методика обычно предполагает использование одного или нескольких инструментальных средств.
Нетрудно заметить, что любой метод, основанный на UML, требует в дополнение к языку только описание процесса, который представляет собой совокупность методик, описывающих выполнение отдельных его шагов. Как уже говорилось ранее, UML – это только язык. На его основе можно создать много разных методов, которые будут существенно различаться, несмотря на единую графическую нотацию. Здесь есть полная аналогия с языками программирования: два программиста, решающие одну и ту же задачу, напишут даже на одном языке программирования разные программы.
В данной и последующих статьях будет рассматриваться Rational Unified Process (RUP), вобравший в себя все лучшее, что есть на сегодняшний день в области организации разработки ПС, включая бизнес-моделирование, управление требованиями, анализ и проектирование, КБ разработку, тестирование, управление конфигурацией и управление изменениями.
RUP – это процесс, направленный на поддержку коллективной разработки ПС. Все участники проекта используют единую базу знаний, единый процесс, единый взгляд на разработку, единый язык моделирования. RUP разрабатывался рука об руку с UML – промышленным стандартом ОО моделирования – тем же коллективом авторов. Все модели в RUP представляются в нотации UML. RUP – это технологический процесс по созданию ПС, позволяющий улучшить производительность коллективной разработки путем предоставления для всех этапов жизненного цикла методик выполнения основных видов деятельности, шаблонов документов, инструкций по работе с инструментальными средствами.
RUP постоянно развивается на основе единой базы знаний, пополняемой через интернет. Это – полезный инструмент, применимый к широкому спектру разрабатываемых приложений.
Классический водопадный жизненный цикл включает этапы анализа требований, проектирования, разработки, сборки и тестирования ПС, выполняемые последовательно. Главный недостаток такого подхода заключается в том, что любое внесение изменений в требования к ПС обходится достаточно дорого. Это происходит потому, что необходимость внесения изменений обнаруживается при таком подходе обычно к концу разработки поэтому требуется править модель всей системы и вносить изменения в программный код большого объема. Такой подход хорош для маленьких проектов и в тех случаях, когда требования к ПС строго определены и гарантированно не будут изменяться. К сожалению, таких проектов в реальной жизни немного.
RUP предлагает итеративный подход к проектированию и разработке ПС, основанный на спиральном жизненном цикле. Весь жизненный цикл включает четыре фазы – вхождение в проект (исследование), развитие (уточнение плана), конструирование и развертывание. Каждая фаза складывается из последовательности итераций, число которых может быть любым. В каждой итерации перечисленные выше технологические процессы последовательно применяются к разработке небольшой части ПС. При этом допустимо предъявление результата заказчику. Он имеет возможность оценить выполненную реализацию, выдать свои замечания, которые могут привести к изменению и уточнению требований к ПС. Следующая итерация предполагает расширение уже разработанной части путем реализации и интеграции очередной порции требований и учета изменения требований в соответствии с замечаниями заказчика. Такая организация процесса имеет целый ряд преимуществ.
Понятие use case, введенное в языке UML, является основой для выполнения всех этапов жизненного цикла, рассматриваемых в RUP. Понятие «business use case» (вид деятельности) является ключевым при бизнес-анализе. На этапах анализа требований, проектирования и реализации use cases выступают в качестве вариантов использования системы (ВИ), являясь той «печкой», от которой «танцуют» аналитики и разработчики при выполнении проектирования и реализации ПС. При анализе требований, выделив ВИ, мы тем самым определяем требование или уровень иерархии требований к ПС. При детализации ВИ определяются объекты, и способы их взаимодействия, которые должны быть реализованы в программном коде.
Следует особо выделить роль ВИ в планировании итераций. Как определить, какая функциональность должна быть реализована в очередной итерации? Здесь на выручку приходят диаграммы ВИ. Каждому ВИ можно приписать приоритет, определяющий, в какой итерации его следует реализовать. Можно показать все ВИ, реализуемые в очередной итерации, на отдельной диаграмме (или нескольких диаграммах).
Архитектура ПС находит отражение в различных архитектурных представлениях.
Логическое представление отражает функциональные требования к системе. Оно определяет основные (архитектурно значимые) пакеты, подсистемы и классы проекта.
Реализационное представление описывает организацию статических программных модулей (компонентов, файлов данных, исходного кода и др.) в терминах пакетов и уровней.
Процедурное представление отражает аспекты параллельности задач, потоков и процессов во время работы системы и их взаимодействия.
Представление развертывания показывает, как компоненты отображаются на базовые платформы и вычислительные узлы.
Use case представление содержит ключевые ВИ и сценарии.
В RUP предусмотрено создание отдельного документа, содержащего описание архитектуры ПС.
Для каждого технологического процесса предусмотрены роли, определяющие поведение и обязанности отдельных лиц и групп, работающих в одной команде (например, системный аналитик, тестировщик), виды деятельности, определяющие работы, выполняемые исполнителями (например, проектирование класса, проектирование ВИ) и артефакты – документы, используемые, порождаемые или модифицируемые процессом. Основные артефакты в RUP – модель, элемент модели, документ, исходный код, исполняемая программа.
В последующих статьях мы рассмотрим технологические процессы и методики их выполнения.