SDLC - модель водопада
Модель Waterfall - это классическая модель SDLC, которая широко известна, понятна и широко используется. Он был представлен Ройсом в 1970 году и до сих пор используется как общий подход к разработке программного обеспечения в различных организациях отрасли.
В модели Waterfall каждая фаза жизненного цикла может начинаться только после завершения более ранней фазы жизненного цикла. Таким образом, это линейная модель без петель обратной связи.
Модель водопада - сильные стороны
Сильные стороны модели Waterfall:
- Легко понять, легко использовать.
- Предоставляет структуру неопытной команде разработчиков.
- Основные вехи хорошо изучены.
- Устанавливает стабильность требований.
- Идеально подходит для управленческого контроля (планирование, мониторинг, отчетность).
- Хорошо работает, когда качество важнее стоимости или графика.
Модель водопада - недостатки
Слабые стороны или недостатки модели водопада:
Идеализированный - не соответствует действительности.
Нереалистично - нельзя ожидать точных требований в начале проекта.
Не отражает итеративный характер более распространенной исследовательской разработки.
Вносить изменения сложно и дорого.
Программное обеспечение доставляется только по окончании проекта. В связи с этим -
Задерживает обнаружение серьезных дефектов.
Возможность доставки устаревших требований.
Значительные накладные расходы на управление, которые могут быть дорогостоящими для небольших команд и проектов.
Требуются опытные ресурсы на каждом этапе - аналитики, дизайнеры, разработчики, тестировщики.
Тестирование начинается только после завершения разработки, и тестировщики не участвуют ни в одном из предыдущих этапов.
Опыт межфункциональных команд не разделяется, поскольку каждый этап выполняется изолированно.
Когда использовать модель водопада?
Вы можете использовать модель водопада, если -
Требования хорошо известны.
Определение продукта стабильное.
Технология хорошо изучена.
Новая версия существующего продукта.
Перенос существующего продукта на новую платформу.
Крупная организация со структурированными кросс-функциональными командами.
Каналы связи хорошо налажены внутри организации, а также с клиентами.
Модель эволюционного прототипирования
При разработке программного обеспечения с использованием модели эволюционного прототипирования разработчики создают прототип на этапе требований. Затем конечные пользователи оценивают прототип и оставляют отзывы. Отзывы могут быть исправлениями к прототипу или дополнительными функциями. Основываясь на отзывах, разработчики дорабатывают прототип.
Таким образом, продукт развивается через циклы Прототип → Обратная связь → Доработанный прототип, отсюда и название «Эволюционное прототипирование». Когда пользователь удовлетворен функциональностью и работой продукта, код прототипа приводится в соответствие с необходимыми стандартами для конечной поставки продукта.
Модель эволюционного прототипирования - сильные стороны
Сильные стороны или преимущества модели эволюционного прототипирования:
Заказчики / конечные пользователи могут визуализировать системные требования по мере их сбора, глядя на прототип.
Разработчики учатся у клиентов, поэтому нет двусмысленностей в отношении предметной области или производственной среды.
Обеспечивает гибкий дизайн и разработку.
Взаимодействие с прототипом стимулирует осознание дополнительно необходимой функциональности.
Неожиданные требования и изменения требований легко приспосабливаются.
Появляются устойчивые и видимые признаки прогресса.
Поставка точного и ремонтопригодного конечного продукта.
Модель эволюционного прототипирования - слабые стороны
Слабые стороны или недостатки модели эволюционного прототипирования заключаются в следующем:
Тенденция отказываться от структурированной разработки в пользу разработки кода и исправлений, хотя это не то, что предписано моделью.
Эта модель получила плохую репутацию за быстрые методы работы.
В целом ремонтопригодность может быть упущена.
Заказчик может запросить доставку прототипа в качестве окончательного, не давая разработчикам возможности выполнить последний шаг, то есть стандартизацию конечного продукта.
Проект может продолжаться вечно (с постоянным расширением масштабов), и руководство может этого не оценить.
Когда использовать модель эволюционного прототипирования?
Вы можете использовать модель эволюционного прототипирования -
- Когда требования нестабильны или требуют уточнения
- Как этап уточнения требований к модели водопада
- Разработать пользовательские интерфейсы
- Для недолговечных демонстраций
- Для новых или оригинальных разработок
- Для внедрения новой технологии