Архитектура Аудит Военная наука Иностранные языки Медицина Металлургия Метрология
Образование Политология Производство Психология Стандартизация Технологии


Этапы разработки программного обеспечения



 

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

Состав процессов жизненного цикла регламентируется международным стандартом ISO/IEC 12207: 1995 «Information Technologe - Software Life Cycle Processes» («Информационные технологии - Процессы жизненного цикла программного обеспечения»). ISO -- International Organization for Standardization - Международная организация по стандартизации. IEC -International Electrotechnical Commission - Международная комиссия по эле­ктротехнике.

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

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

На рис. 1.9 представлены процессы жизненного цикла по указанному стандарту. Каждый процесс характеризуется опреде­ленными задачами и методами их решения, а также исходными данными и результатами.

Процесс разработки (development process) в соответствии со стандартом предусматривает действия и задачи, выполняемые разработчиком, и охваты­вает работы по созданию программного обеспечения и его компонентов в со­ответствии с заданными требованиями, включая оформление проектной и эксплуатационной документации, а также подготовку материалов, необходимых для проверки работоспособности и соответствия качества программных продуктов, материалов, необходимых для обучения персонала, и т. д.

 

 

 

Рис. 1.9. Структура процессов жизненного цикла программного обеспечения

 

По стандарту процесс разработки включает следующие действия:

подготовительную работу - выбор модели жизненного цикла, стандартов, методов и средств разработки, а также составление плана работ;

анализ требований к системе - определение ее функциональных воз­можностей, пользовательских требований, требований к надежности и безо­пасности, требований к внешним интерфейсам и т. д.;

проектирование архитектуры системы - определение состава необ­ходимого оборудования, программного обеспечения и операций, выполняе­мых обслуживающим персоналом;

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

проектирование архитектуры программного обеспечения - определе­ние структуры программного обеспечения, документирование интерфейсов его компонентов, разработку предварительной версии пользовательской до­кументации, а также требований к тестам и плана интеграции;

детальное проектирование программного обеспечения — подробное описание компонентов программного обеспечения и интерфейсов между ни­ми, обновление пользовательской документации, разработка и документиро­вание требований к тестам и плана тестирования компонентов программно­го обеспечения, обновление плана интеграции компонентов;

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

интеграцию программного обеспечения - сборку программных компо­нентов в соответствии с планом интеграции и тестирование программного обеспечения на соответствие квалификационным требованиям, представля­ющих собой набор критериев или условий, которые необходимо выполнить, чтобы квалифицировать программный продукт, как соответствующий своим спецификациям и готовый к использованию в заданных условиях эксплуата­ции;

квалификационное тестирование программного обеспечения - тести­рование программного обеспечения в присутствии заказчика для демон­страции его соответствия требованиям и готовности к эксплуатации; при этом проверяется также готовность и полнота технической и пользователь­ской документации

интеграцию системы - сборку всех компонентов системы, включая программное обеспечение и оборудование;

квалификационное тестирование системы — тестирование системы на соответствие требованиям к ней и проверка оформления и полноты докумен­тации;

установку программного обеспечения - установку программного обес­печения на оборудовании заказчика и проверку его работоспособности;

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

Указанные действия можно сгруппировать, условно выделив следую­щие основные этапы разработки программного обеспечения [10] (в скобках указаны соответствующие стадии разработки по ГОСТ 19.102-77 «Стадии разработки»):

 

• постановка задачи (стадия «Техническое задание»);

• анализ требований и разработка спецификаций (стадия «Эскизный проект»);

• проектирование (стадия «Технический проект»);

• реализация (стадия «Рабочий проект»).

Традиционно разработка также включала этап сопровождения (началу этого этапа соответствует стадия «Внедрение» по ГОСТ). Однако по между­народному стандарту в соответствии с изменениями, произошедшими в ин­дустрии разработки программного обеспечения, этот процесс теперь рассма­тривается отдельно.

Условность выделения этапов связана с тем, что на любом этапе возмож­но принятие решений, которые потребуют пересмотра решений, принятых ранее (см. § 1.5).

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

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

Требования к программному обеспечению, имеющему прототипы, обычно определяют по аналогии, учитывая структуру и характеристики уже существующего программного обеспечения. Для формулирования требова­ний к программному обеспечению, не имеющему аналогов, иногда необходимо провести специальные исследования, называемые предпроектными. В процессе таких исследований определяют разрешимость задачи, возможно, разрабатывают методы ее решения (если они новые) и устанавли­вают наиболее существенные характеристики разрабатываемого программ­ного обеспечения. Для выполнения предпроектных исследований, как прави­ло, заключают договор на выполнение научно-исследовательских работ. В любом случае этап постановки задачи заканчивается разработкой техничес­кого задания, фиксирующего принципиальные требования, и принятием ос­новных проектных решений (см. гл. 3).

Анализ требований и определение спецификаций.

Спецификациями называют точное формализованное описание функций и ограничений разра­батываемого программного обеспечения.

Соответственно различают функ­циональные и эксплуатационные спецификации. Совокупность специфика­ций представляет собой общую логическую модель проектируемого про­граммного обеспечения.

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

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

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

Проектирование. Основной задачей этого этапа является определение подробных спецификаций разрабатываемого программного обеспечения. Процесс проектирования сложного программного обеспечения обычно включает:

• проектирование общей структуры - определение основных компонен­тов и их взаимосвязей;

• декомпозицию компонентов и построение структурных иерархий в со­ответствии с рекомендациями блочно-иерархического подхода;

• проектирование компонентов.

Результатом проектирования является детальная модель разрабатывае­мого программного обеспечения вместе со спецификациями его компонен­тов всех уровней. Тип модели зависит от выбранного подхода (структурный, объектный или компонентный) и конкретной технологии проектирования.

Однако в любом случае процесс проектирования охватывает как проектиро­вание программ (подпрограмм) и определение взаимосвязей между ними, так и проектирование данных, с которыми взаимодействуют эти программы или подпрограммы.

 

Принято различать также два аспекта проектирования:

логическое проектирование, которое включает те проектные операции, которые непосредственно не зависят от имеющихся технических и про­граммных средств, составляющих среду функционирования будущего про­граммного продукта;

физическое проектирование - привязка к конкретным техническим и программным средствам среды функционирования, т. е. учет ограничений, определенных в спецификациях.

 

Реализация.

Реализация представляет собой процесс поэтапного напи­сания кодов программы на выбранном языке программирования (кодирова­ние), их тестирование и отладку.

 

Сопровождение.


Поделиться:



Популярное:

  1. III. Целевые установки, задачи и направления обеспечения транспортной безопасности
  2. IV. Порядок разработки дополнительных противопожарных мероприятий при определении расчетной величины индивидуального пожарного риска
  3. VPN на базе программного обеспечения
  4. Анализ принципов и последовательности разработки финансовой стратегии предприятия
  5. АППАРАТНОГО И ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ
  6. Архитектура промежуточного программного обеспечения
  7. Базовые понятия программного обеспечения реального времени
  8. Безопасность и опасность: свойства и условия возникновения. Этапы защиты от опасностей.
  9. Билет №2. Кадровые технологии. Основные принцыпы разработки.
  10. Биология – теоретическая основа медицины. Методы исследования и этапы развития биологии.
  11. Вопрос 2. Основные этапы развития торговли в России
  12. Вопрос 3 Предмет права социального обеспечения


Последнее изменение этой страницы: 2016-04-11; Просмотров: 1210; Нарушение авторского права страницы


lektsia.com 2007 - 2024 год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! (0.015 с.)
Главная | Случайная страница | Обратная связь