Автор Анна Евкова
Преподаватель который помогает студентам и школьникам в учёбе.

Основы проектирования программ. Этапы создания программного обеспечения ( Понятие и характеристики программы )

Содержание:

ВВЕДЕНИЕ

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

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

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

Цель исследования – рассмотрение основ проектирования программ и этапы их создания.

Задачи работы:

  • охарактеризовать понятие программ;
  • привести классификацию программного обеспечения;
  • проанализировать процесс создания программного обеспечения;
  • рассмотреть этапы создания программного обеспечения.

Объектом исследования выступает процесс создания программного обеспечения, а предметом – этапы этого процесса.

В качестве теоретической базы исследования используются научные труды известных исследователей проектирования программ, а также этапов создания программного обеспечения. В частности, при работе над исследованием использовались работы таких авторов как Голицына О. Л., Зыков С. В., Рудаков А. В. Соколова В. В. и др. Данные авторы на протяжении многих лет осуществляют свою научную деятельность в вопросах создания программного обеспечения, в связи с чем использование результатов их научных изысканий более чем целесообразно в ключе данной работы.

1 Основы проектирования программ

1.1 Понятие и характеристики программы

Программа – это последовательность инструкций (команд), описывающая алгоритм решения с помощью компьютера соответствующей задачи, для реализации которой эта программа была разработана [16]. Для разработки программ используются специальные языки.

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

Готовыми к выполнению являются только программы, содержащие инструкции в двоичном машинном коде, – программы на языке конкретного компьютера (компьютера с процессором определенной модели или семейства), только такие программы можно загрузить в память компьютера для выполнения. Таким образом, программы в машинном коде не являются «переносимыми», их можно выполнять только на компьютерах с общей архитектурой, системой команд, поддерживаемой этими компьютерами, т.е. одинаковым машинным языком [4].

Машинно–ориентированный язык (Assembler) наиболее близок к языку, который «понимает» компьютер. В нем каждая команда, расположенная в отдельной строке, соответствует одной машинной команде. В столбике таблицы, в котором показан шестнадцатеричный машинный код, первое число представляет собой адрес в памяти компьютера, по которому будет при выполнении программы записана команда или данные, машинный код которых следует за этим числом в строке.

Исходный код программы на языке программирования создает программист, используя при этом имеющиеся в его распоряжении редакторы текстов (специальные программы, которые используются для ввода и модификации текстовой информации). Для перевода программы, написанной на языке программирования, в форму, готовую к выполнению (в машинный код), используются специальные системные программы (трансляторы, компоновщики), которые помогают программисту разработать программу. Разработчики применяют различные инструментальные средства, входящие в состав систем программирования, снижающие трудоемкость разработки программ. Современные системы программирования включают в свой состав текстовые редакторы, средства визуального программирования, трансляторы с определенных языков программирования, компоновщики, позволяющие «собрать» программы из отдельно разработанных модулей, и средства отладки программ, позволяющие выявлять и исправлять ошибки в процессе разработки программы [11].

Все программы хранятся в файлах на дисках компьютера. Тип файла определяет способ записи программы в нем. При загрузке программы в память на выполнение она считывается из файла и записывается в выделенную ей для выполнения оперативную память с помощью специальной программы загрузки, так как процессор может прочитать и выполнить только команды, находящиеся в оперативной памяти компьютера [3].

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

1.2 Классификация программного обеспечения

Программное обеспечение (ПО) – это совокупность всех программ и соответствующей документации, обеспечивающая использование ЭВМ в интересах каждого ее пользователя [6].

Различают системное и прикладное ПО. Схематически программное обеспечение можно представить так:

http://inf.e-alekseev.ru/extra/ris49.gif

Рисунок 1 Классификация программного обеспечения

Системное ПО – это совокупность программ для обеспечения работы компьютера. Системное ПО подразделяется на базовое и сервисное. Системные программы предназначены для управления работой вычислительной системы, выполняют различные вспомогательные функции (копирования, выдачи справок, тестирования, форматирования и т. д) [10].

Базовое ПО включает в себя:

  • операционные системы. Операционная система (ОС) является системным программным обеспечением, благодаря которому приводится в действие технические средства компьютера. Это программное обеспечение координирующее работу ЭВМ и производящее управление другими программными модулями посредством скоординированной последовательности операций. Операционные системы для персональных компьютеров делятся на:
  • одно– и многозадачные (в зависимости от числа параллельно выполняемых прикладных процессов);
  • одно– и многопользовательские (в зависимости от числа пользователей, одновременно работающих с операционной системой);
  • непереносимые и переносимые на другие типы компьютеров;
  • несетевые и сетевые, обеспечивающие работу в локальной вычислительной сети ЭВМ [2];
  • оболочки. Операционные оболочки – это специальные программы, предназначенные для облегчения общения пользователя с командами операционной системы. Операционные оболочки имеют текстовый и графический варианты интерфейса конечного пользователя.

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

Во всем мире имеют огромную популярность такие графические оболочки MS DOS как Windows 3.1, Windows 3.11 for WorkGroup, которые позволяют изменить среду взаимодействия пользователя с компьютером, расширяют набор основных (диспетчер файлов, графический редактор, текстовый редактор, картотека и т.п.) и сервисных функций, обеспечивающих пользователю интегрированную информационную технологию [9];

  • сетевые операционные системы – это комплекс программ, обеспечивающий обработку, передачу и хранение данных в сети. Сетевая ОС предоставляет пользователям различные виды сетевых служб (управление файлами, электронная почта, процесс управления сетью и др.), поддерживает работу в абонентских системах. Наибольшее распространение имеют LAN Server, NetWare, VINES.

Они оцениваются по комплексу критериев: производительность, разнообразие возможностей связи пользователей, возможности администрирования [14].

Сервисное ПО включает в себя программы (утилиты):

  • диагностики;
  • антивирусные;
  • обслуживания носителей;
  • архивирования;
  • обслуживания сети [16].

Прикладное ПО – это комплекс программ для решения задач определённого класса конкретной предметной области. Прикладное ПО работает только при наличии системного ПО.

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

  • текстовые процессоры;
  • табличные процессоры;
  • базы данных;
  • интегрированные пакеты;
  • системы иллюстративной и деловой графики (графические процессоры);
  • экспертные системы;
  • обучающие программы;
  • программы математических расчетов, моделирования и анализа;
  • игры;
  • коммуникационные программы [16].

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

  • трансляторы;
  • среду разработки программ;
  • библиотеки справочных программ (функций, процедур);
  • отладчики;
  • редакторы связей и др. [12].

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

2.1 Характеристика процесса создания программного обеспечения

Программное обеспечение (ПО) – компьютерные программы и соответствующая документация. Разрабатывается по частному заказу или для продажи на рынке ПО.

Системотехника (технология создания вычислительных систем) – дисциплина, охватывающая все аспекты создания и модернизации сложных вычислительных систем, где программное обеспечение играет ведущую роль. Сюда можно отнести технологии создания аппаратных средств, создание вычислительных процессов, развертывание всей системы, а также технологию создания непосредственно ПО [8].

Процесс создания ПО – совокупность процессов, приводящих к созданию программного продукта.

Фундаментальные процессы, присущие любому проекту создания ПО:

  1. Разработка спецификации требований на ПО (Определяют функциональные характеристики системы и обязательны для выполнения).
  2. Создание программного обеспечения (создание ПО согласно спецификации).
  3. Аттестация ПО (Созданное ПО должно пройти аттестацию для подтверждения соответствию требованиям заказчика).
  4. Модернизация ПО (совершенствование ПО согласно измененным требованиям потребителя) [7].

Модель процесса создания ПО – последовательность этапов, необходимых для разработки создаваемого ПО.

Модели процесса разработки ПО:

  1. Каскадная модель.
  2. Эволюционная модель.
  3. Формальное преобразование.
  4. Сборка программных продуктов из ранее созданных компонентов (модель сборки).
  5. Итерационная (спиральная) модель [16].

Методы создания ПО представляют собой структурный подход к созданию ПО, который способствует производству ПО эффективным, с экономической точки зрения, способом.

Все методы основаны на использовании моделей системы в качестве спецификации ее структуры:

  1. Функционально–ориентированные (структурный анализ, JSD, 70–е годы) основаны на определении основных функциональных компонент системы.
  2. Объектно–ориентированные (Booch, Rumbaugh) используют подходы, основанные на использовании унифицированного языка моделирования UML.
  3. Computer–Aided Software Engineering – автоматизированная разработка ПО [11].

Базовые процессы создания ПО можно представить в виде следующей последовательности:

  1. Разработка спецификации.
  2. Проектирование и реализация.
  3. Аттестация.
  4. Эволюция [15].

Жизненный цикл ПО – совокупность процессов, протекающих от момента принятия решения о создании ПО до его полного вывода из эксплуатации.

Каскадная модель (рисунок 2)

Картинки по запросу каскадная модель создания по

Рисунок 2 Каскадная модель разработки программного обеспечения

Достоинства:

  • документирование каждого этапа.

Недостатки:

  • «негибкое» разбиение процесса создания на отдельные этапы.

Применение:

  • требования сформулированы достаточно четко;
  • повсеместно для разработки небольших систем, входящих в состав крупного проекта [12].

Эволюционная модель (рисунок 3)

Картинки по запросу эволюционная модель создания по

Рисунок 3 Эволюционная модель разработки программного обеспечения

Прототип – действующий программный модуль, реализующий отдельные функции создаваемого ПО.

Достоинства:

  • спецификация разрабатывается постепенно, по мере требования заказчика.

Недостатки:

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

Применение:

  • разработка небольших систем (<100 000 строк) или средних (<500 000 строк) с относительно коротким сроком жизни [1].

Формальная разработка

Достоинства:

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

Недостатки:

  • требуют специальных знаний и опыта использования;
  • не дают существенного выигрыша в стоимости разработки;
  • большинство сложных систем с трудом поддаются формальному описанию [1].

Модель пошаговой разработки (рисунок 4)

Картинки по запросу модель пошаговой разработки создания по

Рисунок 4 Модель пошаговой разработки программного обеспечения

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

Достоинства:

  • нет необходимости ждать полного завершения разработки системы;
  • можно использовать компоненты, полученные на первых шагах, как прототипы;
  • уменьшается риск общесистемных ошибок;
  • системные сервисы с высоким приоритетом разрабатываются первыми, а все последующие интегрируются с ними. Это позволяет снизить вероятность программных ошибок в особо важных частях системы.

Недостатки:

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

Спиральная модель (рисунок 5).

Картинки по запросу спиральная модель  создания по

Рисунок 5 Спиральная модель разработки программного обеспечения

Достоинства:

  • нет фиксированных этапов;
  • эта модель может включать в себя любые другие модели на каждом витке спирали:
  • прототипирование может использоваться при нечетком определении требований;
  • каскадная модель в случае последовательного выполнения некоторых этапов;
  • модель формальных преобразований – если четко сформулированы требования.

Недостатки:

  • сложная автоматизация процессов разработки;
  • огромная роль при разработке системы отводится управлению проектом [12].

Базовые процессы создания ПО

Разработка спецификации ПО – определение сервисов, которыми будет обладать создаваемое ПО, а также ограничений, налагаемых на функциональные возможности и разработку ПО.

Результат процесса определения требований – документация, формализующая требования, предъявляемые к системе.

Два уровня детализации:

  • требования, предъявляемые конечными пользователями;
  • системная спецификация для разработчиков [13].

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

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

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

Методы проектирования – множество формализованных нотаций и нормативных документов для проектирования ПО.

Структурные методы поддерживают модели системы:

  • модель потоков данных;
  • модель «сущность–связь»;
  • структурная модель;
  • объектно–ориентированные иерархическая модель системы, модель отношений между объектами, модель взаимодействия объектов;
  • диаграммы переходов или сценарии жизни сущностей [11].

Программирование и отладка:

Тестирование – процесс установления программных ошибок.

Отладка – установление местоположения ошибок и их устранение.

Аттестация и верификация – процесс установления соответствия ПО ее спецификации, а также ожиданиям и требованиям пользователей и заказчика.

Сопровождение системы – это внесение изменений в систему, которая находится в эксплуатации [8].

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

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

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

Анализ требований

Самым первым этапом разработки программного обеспечения по праву называется процедура проведения всестороннего анализа выдвинутых заказчиком требований к создаваемому ПО, чтобы определить ключевые цели и задачи конечного продукта. В рамках этой стадии происходит максимально эффективное взаимодействие нуждающегося в программном решении клиента и сотрудников компании–разработчика, в ходе обсуждения деталей проекта помогающих более четко сформулировать предъявляемые к ПО требования. Результатом проведенного анализа становится формирование основного регламента, на который будет опираться исполнитель в своей работе – технического задания на разработку программного обеспечения. ТЗ должно полностью описывать поставленные перед разработчиком задачи и охарактеризовать конечную цель проекта в понимании заказчика [5].

Проектирование

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

В рамках данного этапа стороны должны осуществить:

  • оценку результатов проведенного первоначально анализа и выявленных ограничений;
  • поиск критических участков проекта;
  • формирование окончательной архитектуры создаваемой системы;
  • анализ необходимости использования программных модулей или готовых решений сторонних разработчиков;
  • проектирование основных элементов продукта – модели базы данных, процессов и кода;
  • выбор среды программирование и инструментов разработки, утверждение интерфейса программы, включая элементы графического отображения данных;
  • определение основных требований к безопасности разрабатываемого ПО [11].

Кодирование

Следующим шагом становится непосредственная работа с кодом, опираясь на выбранный в процессе подготовки язык программирования. Описывать особенности и тонкости самого трудоемкого и сложного этапа вряд ли стоит, достаточно указать, что успех реализации любого проекта напрямую зависит от качества предварительного анализа и оценки конкурирующих решений, с которыми создаваемой программе предстоит «бороться» за право называться лучшей в своей нише. Если речь идет о написании кода для выполнения узкоспециализированных задач в рамках конкретного предприятия, то от грамотного подхода к этапу кодирования зависит эффективность работы компании, заказавшей разработку. Кодирование может происходить параллельно со следующим этапом разработки – тестированием программного обеспечения, что помогает вносить изменения непосредственно по ходу написания кода. Уровень и эффективность взаимодействия всех элементов, задействованных для выполнения сформулированных задач компанией–разработчиком, на текущем этапе является самым важным – от слаженности действий программистов, тестировщиков и проектировщиков зависит качество реализации проекта [12].

Тестирование и отладка

После достижения задуманного программистами в написанном коде следуют не менее важные этапы разработки программного обеспечения, зачастую объединяемые в одну фазу – тестирование продукта и последующая отладка, позволяющая ликвидировать огрехи программирования и добиться конечной цели – полнофункциональной работы разработанной программы. Процесс тестирования позволяет смоделировать ситуации, при которых программный продукт перестает функционировать. Отдел отладки затем локализует и исправляет обнаруженные ошибки кода, «вылизывая» его до практически идеального состояния. Эти два этапа занимают не меньше 30% затрачиваемого на весь проект времени, так как от их качественного исполнения зависит судьба созданного силами программистов программного обеспечения. Нередко функции тестировщика и отладчика исполняет один отдел, однако самым оптимальным будет распределить эти обязанности между разными исполнителями, что позволит увеличить эффективность поиска имеющихся в программном коде ошибок [8].

Внедрение

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

  • первоначальная загрузка данных;
  • постепенное накопление информации;
  • вывод созданного ПО на проектную мощность.

Ключевой целью поэтапного внедрения разработанной программы становится постепенное выявление не обнаруженных ранее ошибок и недочетов кода. В рамках этого этапа разработки программного обеспечения и заказчик, и исполнитель могут столкнуться с рядом достаточно узкого спектра ошибок, связанных с частичной рассогласованностью данных при их загрузке в БД, а также срывов выполнения программных процедур в связи с применением многопользовательского доступа. Именно на этой стадии выкристаллизовывается окончательная картина взаимодействия пользователя с программой, а также определяется степень лояльности последнего к разработанному интерфейсу. Если выход системы на проектную мощность после ряда проведенных доработок и улучшений произошел без особых осложнений, значит предварительная работа над проектом и реализация предыдущих стадий разработки осуществлялась правильно [16].

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

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

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

ЗАКЛЮЧЕНИЕ

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

  • охарактеризовано понятие программ;
  • приведена классификация программного обеспечения;
  • проанализирован процесс создания программного обеспечения;
  • рассмотрены этапы создания программного обеспечения.

Благодаря выполнению названных задач была достигнута поставленная цель – рассмотрены основы проектирования программ и этапы создания таких программ.

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

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

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

СПИСОК ИСТОЧНИКОВ

  1. Гагарина, Л. Г. Введение в архитектуру программного обеспечения. Учебное пособие / Л. Г. Гагарина, А. Р. Федоров, П. А. Федоров. – М.: Инфра–М, Форум, 2016. – 320 c.
  2. Голицына, О. Л. Программное обеспечение / О. Л. Голицына, И. И. Попов, Т. Л. Партыка. – М.: Форум, 2015. – 448 c.
  3. Гончаров, В. А. Методы оптимизации. Учебное пособие / В. А. Гончаров. – М.: Юрайт, 2015. – 192 c.
  4. Добрынин, В. Ю. Технологии компонентного программирования / В. Ю. Добрынин. – Москва: Гостехиздат, 2014. – 216 c.
  5. Емельянова, Н. З. Проектирование информационных систем / Н. З. Емельянова, Т. Л. Партыка, И. И. Попов. – М.: Форум, 2018. – 432 c.
  6. Затонский, А. В. Программирование и основы алгоритмизации / А. В. Затонский, Н.В. Бильфельд. – М.: Дрофа, 2014. – 176 c.
  7. Зыков, С. В. Основы современного программирования / С. В. Зыков. – М.: Горячая линия – Телеком, 2016. – 448 c.
  8. Карпенко, А. П. Современные алгоритмы оптимизации. Учебное пособие / А. П. Карпенко. – М.: МГТУ им. Н. Э. Баумана, 2014. – 448 c.
  9. Колдаев, В. Д. Основы логического проектирования / В. Д. Колдаев. – Москва: РГГУ, 2017. – 448 c.
  10. Лукин, В. В. Технология разработки программного обеспечения. Учебное пособие / В. В. Лукин, В. Н. Лукин, Т. В. Лукин. – Москва: Гостехиздат, 2015. – 286 c.
  11. Милов, А. В. Основы программирования в задачах и примерах / А. В. Милов. – М.: Фолио, 2017. – 400 c.
  12. Панюкова, Т. А. Проектирование программных средств / Т. А. Панюкова. – Москва: Гостехиздат, 2017. – 364 c.
  13. Рудаков, А. В. Технология разработки программных продуктов. Учебник / А. В. Рудаков. – М.: Академия, 2015. – 208 c.
  14. Сафонов, В. О. Аспектно–ориентированное программирование / В. О. Сафонов. – Москва: Высшая школа, 2016. – 104 c.
  15. Семакин, И. Г. Основы алгоритмизации и программирования / И. Г. Семакин, А. П. Шестаков. – М.: Academia, 2017. – 304 c.
  16. Соколова, В. В. Вычислительная техника и информационные технологии. Разработка мобильных приложений. Учебное пособие / В. В. Соколова. – Москва: Высшая школа, 2016. – 176 c.