Процеси життєвого циклу для розвитку програмних засобів

Автор: Пользователь скрыл имя, 10 Июня 2013 в 01:15, реферат

Описание работы

• Основні:
o Придбання (дії і завдання замовника, що здобуває ПО)
o Поставка (дії і завдання постачальника, який постачає замовника програмним продуктом або послугою)
o Розробка (дії і завдання, що виконуються розробником: створення ПО, оформлення проектної та експлуатаційної документації, підготовка тестових та навчальних матеріалів і т. д.)
o Експлуатація (дії і завдання оператора - організації, що експлуатує систему)

Содержание

1. Процеси життєвого циклу ПО 3
2. Стадії життєвого циклу ПЗ, взаємозв'язок між процесами і стадіями 4
3. Моделі життєвого циклу ПО 5
3.1. Водопадна (каскадна, послідовна) модель 5
3.2. Ітераційна модель 6
3.3. Спіральна модель 7
4. Методології розробки ПЗ 9
5. Адаптація стандарту до конкретного проекту 9
Література 13

Работа содержит 1 файл

SDLC.docx

— 80.84 Кб (Скачать)

МІНІСТЕРСТВО ОСВІТИ І НАУКИ, МОЛОДІ ТА СПОРТУ УКРАЇНИ

НАЦІОНАЛЬНИЙ ЛІСОТЕХНІЧНИЙ УНІВЕРСИТЕТ УКРАЇНИ

 

 

Кафедра ОТ і МПТ

 

 

 

РЕФЕРАТ

 

на тему

" Процеси життєвого циклу для розвитку програмних засобів"

 

 

Виконав:

Студент групи КН-41/2

Повшука О.В.

Прийняв:

ст. викладач ОТіМПТ

Пірко І. Б.

 

 

 

Львів – 2013

 

ЗМІСТ

 

1. Процеси життєвого циклу ПО 3

2. Стадії життєвого циклу ПЗ, взаємозв'язок між процесами і стадіями 4

3. Моделі життєвого циклу ПО 5

3.1. Водопадна (каскадна, послідовна) модель 5

3.2. Ітераційна модель 6

3.3. Спіральна модель 7

4. Методології розробки ПЗ 9

5. Адаптація стандарту до конкретного проекту 9

Література 13

 

 

  1. Процеси життєвого циклу ПО

  • Основні:
    • Придбання (дії і завдання замовника, що здобуває ПО)
    • Поставка (дії і завдання постачальника, який постачає замовника програмним продуктом або послугою)
    • Розробка (дії і завдання, що виконуються розробником: створення ПО, оформлення проектної та експлуатаційної документації, підготовка тестових та навчальних матеріалів і т. д.)
    • Експлуатація (дії і завдання оператора - організації, що експлуатує систему)
    • Супровід (дії і завдання, що виконуються супроводжує організацією, тобто службою супроводу). Супровід - внесень змін в ПЗ з метою виправлення помилок, підвищення продуктивності або адаптації до нових умов роботи або вимогам.
  • Допоміжні
    • Документування (формалізований опис інформації, створеної протягом ЖЦ ПО)
    • Управління конфігурацією (застосування адміністративних і технічних процедур на всьому протязі ЖЦ ПО для визначення стану компонентів ПЗ, управління його модифікаціями).
    • Забезпечення якості (забезпечення гарантій того, що ІС і процеси її ЖЦ відповідають заданим вимогам та затвердженим планам)
    • Верифікація (визначення того, що програмні продукти, які є результатами певної дії, повністю задовольняють вимогам або умовам, обумовленим попередніми діями)
    • Атестація (визначення повноти відповідності заданих вимог і створеної системи їх конкретному функціональному призначенню)
    • Спільна оцінка (оцінка стану робіт по проекту: контроль планування та управління ресурсами, персоналом, апаратурою, інструментальними засобами)
    • Аудит (визначення відповідності вимогам, планам і умов договору)
    • Дозвіл проблем (аналіз і рішення проблем, незалежно від їх походження чи джерела, які виявлені в ході розробки, експлуатації, супроводу або інших процесів)
  • Організаційні
    • Управління (дії і завдання, які можуть виконуватися будь-якою стороною, що управляє своїми процесами)
    • Створення інфраструктури (вибір та супровід технології, стандартів та інструментальних засобів, вибір і установка апаратних і програмних засобів, що використовуються для розробки, експлуатації чи супроводу ПО)
    • Удосконалення (оцінка, вимір, контроль та вдосконалення процесів ЖЦ)
    • Навчання (початкове навчання і подальше постійне підвищення кваліфікації персоналу)

Кожен процес включає ряд дій. Наприклад, процес придбання охоплює наступні дії:

  1. Ініціювання придбання
  2. Підготовка заявочних пропозицій
  3. Підготовка та коригування договору
  4. Нагляд за діяльністю постачальника
  5. Приймання та завершення робіт

Кожна дія включає ряд завдань. Наприклад, підготовка заявочних пропозицій повинна передбачати:

  1. Формування вимог до системи
  2. Формування списку програмних продуктів
  3. Встановлення умов і угод
  4. Опис технічних обмежень (середовище функціонування системи і т. д.)
  1. Стадії життєвого циклу ПЗ, взаємозв'язок між процесами і стадіями

Модель життєвого циклу  ПЗ - структура, що визначає послідовність виконання та взаємозв'язку процесів, дій і завдань протягом життєвого циклу. Модель життєвого циклу залежить від специфіки, масштабу і складності проекту і специфіки умов, в яких система створюється і функціонує.

Стандарт ДСТУ ISO / IEC 12207-99 не пропонує конкретну модель життєвого циклу. Його положення є загальними для  будь-яких моделей життєвого циклу, методів і технологій створення  ІС. Він описує структуру процесів життєвого циклу, не конкретизуючи, як реалізувати або виконати дії  і завдання, включені в ці процеси.

Модель ЖЦ ПЗ включає в себе:

  1. Стадії;
  2. Результати виконання робіт на кожній стадії;
  3. Ключові події - точки завершення робіт і прийняття рішень.

Стадія - частина процесу створення ПЗ, обмежена певними тимчасовими рамками і закінчується випуском конкретного продукту (моделей, програмних компонентів, документації), що визначається заданими для даної стадії вимогами.

На кожній стадії можуть виконуватися декілька процесів, визначених у стандарті  ДСТУ ISO / IEC 12207-99, і навпаки, один і  той же процес може виконуватися на різних стадіях. Співвідношення між  процесами і стадіями також визначається використовуваної моделлю життєвого  циклу ПЗ.

  1. Моделі життєвого циклу ПО

    1. Водопадна (каскадна, послідовна) модель

Водопадна модель життєвого циклу ( англ. waterfall model ) була запропонована в 1970 р. Уїнстоном Ройсом. Вона передбачає послідовне виконання всіх етапів проекту в строго фіксованому порядку. Перехід на наступний етап означає повне завершення робіт на попередньому етапі. Вимоги, визначені на стадії формування вимог, суворо документуються у вигляді технічного завдання і фіксуються на весь час розробки проекту. Кожна стадія завершується випуском повного комплекту документації, достатньої для того, щоб розробка могла бути продовжена іншою командою розробників.

Етапи проекту відповідно до каскадної  моделлю:

  1. Формування вимог;
  2. Проектування;
  3. Реалізація;
  4. Тестування;
  5. Впровадження;
  6. Експлуатація та супровід.

 

Переваги:

  • Повна і узгоджена документація на кожному етапі;
  • Легко визначити терміни і витрати на проект.

Недоліки:

У Водоспадної моделі перехід від  однієї фази проекту до іншого передбачає повну коректність результату (виходу) попередньої фази. Однак неточність вимозі або некоректна його інтерпретація в результаті призводить до того, що доводиться "відкочуватися" до ранньої фази проекту і необхідна переробка не просто вибиває проектну команду з графіка, але призводить часто до якісного зростання витрат і, не виключено, до припинення проекту в тій формі, в якій він спочатку замислювався. На думку сучасних фахівців, основне оману авторів Водоспадної моделі полягає в припущеннях, що проект проходить через весь процес один раз, спроектована архітектура хороша і проста у використанні, проект здійснення розумний, а помилки в реалізації легко усуваються в міру тестування. Ця модель виходить з того, що всі помилки будуть зосереджені в реалізації, а тому їх усунення відбувається рівномірно під час тестування компонентів і системи [2]. Таким чином, Водопадна модель для великих проектів мало реалістична і може бути ефективно використана тільки для створення невеликих систем [3].

    1. Ітераційна модель

Альтернативою послідовної моделі є так звана модель ітеративної  і інкрементального розробки ( англ. iterative and incremental development, IID ), Що отримала також від Т. Гілба в 70-і рр.. назву еволюційної моделі. Також цю модель називають ітеративної модель інкрементальний моделлю [4].

Модель IID передбачає розбиття життєвого  циклу проекту на послідовність  ітерацій, кожна з яких нагадує "міні-проект", включаючи всі процеси розробки в застосуванні до створення менших фрагментів функціональності, порівняно  з проектом в цілому. Мета кожної ітерації - отримання працюючої версії програмної системи, що включає функціональність, визначену інтегрованим змістом всіх попередніх та поточної ітерації. Результат фінальної ітерації містить всю необхідну функціональність продукту. Таким чином, із завершенням кожної ітерації продукт отримує приріст - інкремент - до його можливостей, які, отже, розвиваються еволюційно. Ітеративного, інкрементального і еволюційність в даному випадку є вислів одного і те ж сенсу різними словами зі злегка різних точок зору [3].

За висловом Т. Гілба, "еволюція - прийом, призначений для створення видимості стабільності. Шанси успішного створення складної системи будуть максимальними, якщо вона реалізується в серії невеликих кроків і якщо кожен крок містить в собі чітко певний успіх, а також можливість" відкоту "до попереднього успішному етапу в разі невдачі. Перед тим, як пустити в справу всі ресурси, призначені для створення системи, розробник має можливість одержувати з реального світу сигнали зворотного зв'язку і виправляти можливі помилки в проекті " [4].

Підхід IID має і свої негативні  сторони, які, по суті, - зворотна сторона  достоїнств. По-перше, цілісне розуміння  можливостей і обмежень проекту  дуже довгий час відсутня. По-друге, при ітераціях доводиться відкидати  частину зробленої раніше роботи. По-третє, сумлінність фахівців при  виконанні робіт все ж знижується, що психологічно зрозуміло, адже над  ними постійно тяжіє відчуття, що "все  одно все можна буде переробити і  поліпшити пізніше" [3].

Різні варіанти ітераційного підходу  реалізовані в більшості сучасних методологій розробки ( RUP, MSF, XP).

    1. Спіральна модель

Спіральна модель ( англ. spiral model ) Була розроблена в середині 1980-х років Баррі Боем. Вона заснована на класичному циклі Демінга PDCA (plan-do-check-act). При використанні цієї моделі ПО створюється в кілька ітерацій (витків спіралі) методом прототипування.

Кожна ітерація відповідає створенню  фрагмента або версії ПЗ, на ній  уточнюються цілі і характеристики проекту, оцінюється якість отриманих результатів і плануються роботи наступної ітерації.

На кожній ітерації оцінюються:

  • ризик перевищення термінів і вартості проекту;
  • необхідність виконання ще однієї ітерації;
  • ступінь повноти і точності розуміння вимог до системи;
  • доцільність припинення проекту.

Важливо розуміти, що спіральна модель є не альтернативою еволюційної  моделі (моделі IID), а спеціально опрацьованим варіантом. На жаль, нерідко спіральну  модель або помилково використовують як синонім еволюційної моделі взагалі, або (не менш помилково) згадують як абсолютно  самостійну модель поряд з IID [3].

Відмінною особливістю спіральної моделі є спеціальна увага, що приділяється ризикам, що впливає на організацію  життєвого циклу, і контрольним  точкам. Боем формулює 10 найбільш поширених (за пріоритетами) ризиків:

  1. Дефіцит фахівців.
  2. Нереалістичні терміни і бюджет.
  3. Реалізація невідповідної функціональності.
  4. Розробка неправильного користувальницького інтерфейсу.
  5. Перфекціонізм, непотрібна оптимізація і відточування деталей.
  6. Безперервний потік змін.
  7. Брак інформації про зовнішні компоненти, що визначають оточення системи або залучених до інтеграцію.
  8. Недоліки в роботах, виконуваних зовнішніми (по відношенню до проекту) ресурсами.
  9. Недостатня продуктивність одержуваної системи.
  10. Розрив у кваліфікації фахівців різних областей.

У сьогоднішній спіральної моделі визначено  такий загальний набір контрольних  точок [5] :

  1. Concept of Operations (COO) - концепція (використання) системи;
  2. Life Cycle Objectives (LCO) - цілі та зміст життєвого циклу;
  3. Life Cycle Architecture (LCA) - архітектура життєвого циклу; тут же можливо говорити про готовність концептуальної архітектури цільової програмної системи;
  4. Initial Operational Capability (IOC) - перша версія створюваного продукту, придатна для дослідної експлуатації;
  5. Final Operational Capability (FOC) - готовий продукт, розгорнутий (встановлений і налаштований) для реальної експлуатації.

Информация о работе Процеси життєвого циклу для розвитку програмних засобів