- •1.Технология программирования и основные этапы ее развития
- •2.Основные подходы к программированию
- •3.«Стихийное» программирование. Структурный подход к программированию
- •4.Метод пошаговой детализации
- •5.Объектный подход к программированию
- •6.Компонентный подход. Case-технологии
- •7.Блочно-иерархический подход к созданию сложных систем
- •8.Жизненный цикл программного обеспечения
- •9.Этапы разработки программного обеспечения
- •10.Эволюция моделей жизненного цикла программного обеспечения.
- •11.Ускорение разработки программного обеспечения. Технология rad. Основные положения технологии rad
- •12.Оценка качества процессов создания программного обеспечения
- •13.Модули и их свойства
- •14.Нисходящая и восходящая разработка программного обеспечения
- •15.Структурное и «неструктурное» программирование
- •16.Способы экономии памяти
- •17,Программирование «с защитой от ошибок»
- •18,Классификация программных продуктов по функциональному признаку
- •19.Основные эксплуатационные требования к программным продуктам
- •20,Типы пользовательских интерфейсов. Выбор типа интерфейса
- •21.Психофизические особенности человека, связанные с восприятием, запоминанием и обработкой информации
- •22.Классификации диалогов
- •23.Техническое задание.
- •24.Выбор архитектуры программного обеспечения
- •25.Структурная и функциональная схема разрабатываемого программного обеспечения.
- •26.Тестирование и отладка.
23.Техническое задание.
. Техническое задание представляет собой документ, в котором сформулированы основные цели разработки, требования к программному продукту, определены сроки и этапы разработки и регламентирован процесс приемно-сдаточных испытаний. В разработке технического задания участвуют как представители заказчика, так и представители исполнителя. В основе этого документа лежат исходные требования заказчика, анализ передовых достижений техники, результаты выполнения научно-исследовательских работ, предпроектных исследований, научного прогнозирования и т. п. Основными факторами, определяющими характеристики разрабатываемого ПО являются:
а) исходные данные и требуемые результаты, определяющие функции программы или системы;
б) среда функционирования (программная и аппаратная) - задается или выбирается для обеспечения параметров, указанных в техническом задании;
в) возможное взаимодействие с другим программным обеспечением и/или специальными техническими средствами - задается или выбирается исходя из набора выполняемых функций.
Разработка технического задания - процесс трудоемкий, требующий определенных навыков, выполняется в следующей последовательности. Прежде всего, устанавливают набор выполняемых функций, а также перечень и характеристики исходных данных. Затем определяют перечень результатов, их характеристики и способы представления. Далее уточняют среду функционирования ПО: конкретную комплектацию и параметры технических средств, версию используемой операционной системы, версии и параметры другого установленного ПО, с которым предстоит взаимодействовать будущему программному продукту. В случаях, когда разрабатываемое ПО собирает и хранит некоторую информацию или включается в управление каким-либо техническим процессом, необходимо также четко регламентировать действия программы в случае сбоев оборудования и энергоснабжения.
На техническое задание существует стандарт ГОСТ 19.201-78 «Техническое задание. Требования к содержанию и оформлению». В соответствии с этим стандартом техническое задание должно содержать следующие разделы:
а) введение;
б) основания для разработки;
в) назначение разработки;
г) требования к программе или программному изделию;
д) требования к программной документации;
е) технико-экономические показатели;
ж) стадии и этапы разработки;
з) порядок контроля и приемки.
24.Выбор архитектуры программного обеспечения
Архитектурой программного обеспечения называют совокупность базовых концепций (принципов) его построения. Архитектура программного обеспечения определяется сложностью решаемых задач, степенью универсальности разрабатываемого программного обеспечения и числом пользователей, одновременно работающих с одной его копией. Различают:
• однопользовательскую архитектуру, при которой программное обеспечение рассчитано на одного пользователя, работающего за персональным компьютером;
• многопользовательскую архитектуру, которая рассчитана на работу в локальной или глобальной сети.
Кроме того, в рамках однопользовательской архитектуры различают:
• программы;
• пакеты программ;
• программные комплексы;
• программные системы.
Многопользовательскую архитектуру реализуют системы, построенные по принципу «клиент-сервер» (см. § 1.1).
Программой называют адресованный компьютеру набор инструкций, точно описывающий последовательность действий, которые необходимо выполнить для решения конкретной задачи. При структурном подходе программы представляют собой иерархию подпрограмм, вызывающих друг друга в процессе решения поставленной задачи, при объектном подходе - совокупность обменивающихся сообщениями объектов, для реализации которых разработаны специальные классы. Программа в этом случае представляет собой отдельно компилируемую программную единицу, которая может использовать стандартные библиотеки подпрограмм, но, как правило, не организует свои. Это самый простой вид архитектуры, который обычно используется при решении небольших задач.
Пакеты программ представляют собой совокупность программ, решающих задачи некоторой прикладной области. Например, пакет графических программ, пакет математических программ. Программы такого пакета связаны между собой только принадлежностью к определенной прикладной области. Пакет программ реализуют как набор отдельных программ, каждая из которых сама вводит необходимые данные и выводит результаты. По сути дела пакет программ - это некоторая библиотека программ.
Программные комплексы представляют собой совокупность программ, совместно обеспечивающих решение небольшого класса сложных задач одной прикладной области. Для решения такой задачи может потребоваться решить несколько подзадач, последовательно вызывая программы комплекса. Вызов программ в программном комплексе осуществляется специальной программой - диспетчером, который обеспечивает несложный интерфейс с пользователем и, возможно, выдачу некоторой справочной информации. От пакета программ программный комплекс отличается еще и тем, что несколько программ могут последовательно или циклически вызываться для решения одной задачи, и, следовательно, желательно хранить исходные данные и результаты вызовов в пределах одного пользовательского проекта. Программы в этом случае могут реализовываться как отдельно, так и как совместно компилируемые программные единицы, а исходные данные храниться в оперативной памяти или в файлах.
Программные системы представляют собой организованную совокупность программ (подсистем), позволяющую решать широкий класс задач из некоторой прикладной области. В отличие от программных комплексов программы, входящие в программную систему, взаимодействуют через общие данные. Программные системы обычно имеют развитые пользовательский и внутренние интерфейсы, что требует их тщательного проектирования.
Многопользовательские программные системы в отличие от обычных программных систем должны организовывать сетевое взаимодействие отдельных компонентов программного обеспечения, что еще усложняет процесс его разработки. Для разработки подобного программного обеспечения используют специальные технологии или платформы, например, технологии CORBA, COM, Java и т. п.