Адаптивная разработка программного обеспечения - жизненный цикл

Адаптивная разработка программного обеспечения произошла от практики RAD. К этим практикам также были добавлены командные аспекты. Компании от Новой Зеландии до Канады для широкого спектра проектов и типов продуктов использовали адаптивную разработку программного обеспечения.

Джим Хайсмит опубликовал книгу «Адаптивная разработка программного обеспечения» в 2000 году.

Практики адаптивной разработки программного обеспечения дают возможность приспосабливаться к изменениям и могут быть адаптированы в нестабильных условиях, когда продукты развиваются без особого планирования и обучения.

Фазы жизненного цикла РАС

Адаптивная разработка программного обеспечения циклична, как и эволюционная модель, с названиями фаз, отражающими непредсказуемость сложных систем. Фазы жизненного цикла адаптивной разработки:

  • Speculate
  • Collaborate
  • Learn

Эти три этапа отражают динамичный характер разработки адаптивного программного обеспечения. Адаптивное развитие явно заменяет детерминизм на эмерджентность. Это не просто изменение жизненного цикла, а более глубокое изменение стиля управления. Адаптивная разработка программного обеспечения имеет динамический жизненный цикл: размышление-сотрудничество-изучение.

Жизненный цикл адаптивной разработки программного обеспечения ориентирован на результаты, а не на задачи, и результаты идентифицируются как функции приложения.

Размышлять

Термин план слишком детерминирован и указывает на достаточно высокую степень уверенности в желаемом результате. Неявная и явная цель соответствия плану ограничивает способность менеджера направлять проект в инновационном направлении.

В адаптивной разработке программного обеспечения термин «план» заменен термином «спекулировать». Спекулируя, команда не отказывается от планирования, но признает реальность неопределенности сложных проблем. Спекуляция поощряет исследования и эксперименты. Приветствуются итерации с короткими циклами.

Сотрудничать

Сложные приложения не создаются, они развиваются. Сложные приложения требуют сбора, анализа и применения большого объема информации для решения проблемы. В турбулентных средах поток информации высок. Следовательно, сложные приложения требуют, чтобы большой объем информации был собран, проанализирован и применен к проблеме. Это приводит к разнообразным требованиям к знаниям, которые могут быть выполнены только при совместной работе команды.

Сотрудничество потребует способности работать совместно для получения результатов, обмена знаниями или принятия решений.

В контексте управления проектами сотрудничество отображает баланс между управлением с использованием традиционных методов управления и созданием и поддержанием среды совместной работы, необходимой для появления.

Учиться

Часть жизненного цикла обучения жизненно важна для успеха проекта. Команда должна постоянно расширять свои знания, используя такие практики, как:

  • Технические обзоры
  • Ретроспективы проекта
  • Группы поддержки клиентов

Обзоры следует делать после каждой итерации. И разработчики, и клиенты проверяют свои предположения и используют результаты каждого цикла разработки, чтобы узнать направление следующего. Команда учится -

  • Об изменениях в продукте

  • Более фундаментальные изменения в основных предположениях о том, как разрабатываются продукты

Итерации должны быть короткими, чтобы команда могла учиться на мелких, а не на крупных ошибках.

Спекуляция - Сотрудничество - Цикл обучения в целом

Как вы заметили из цикла «Спекуляция-Сотрудничество-Обучение», приведенного выше, очевидно, что три фазы нелинейны и перекрываются.

Мы наблюдаем следующее из адаптивного фреймворка.

  • Трудно сотрудничать без обучения или учиться без сотрудничества.

  • Трудно рассуждать без обучения или учиться без размышлений.

  • Трудно спекулировать без сотрудничества или сотрудничать без спекуляции.