Главная страница
Навигация по странице:

  • УДК 681.3.06(075.8) ББК 32.973-018 © Г.С. Иванова, 2002 ISBN

  • Введение ............................................................................................……………10 1. Технология программирования. Основные понятия и подходы………..12

  • 2. Приемы обеспечения технологичности программных продуктов………..45

  • 3. Определение требований к программному обеспечению и исходных данных для его проектирования .................................................…………………75

  • 4. Анализ требований и определение спецификаций программного обеспечения при структурном подходе........................................………………….103

  • 5. Проектирование программного обеспечения при структурном подходе………139

  • 6. Анализ требований и определение спецификаций программного обеспечения при объектном подходе ...........................................…………………….167

  • 9. Тестирование программных продуктов ....................................…………………..263

  • 10. Отладка программного обеспечения ..................................... …………………..287

  • 11.Составление программной документации ...............................…………………..300

  • Список литературы ....................................................................... ……………………315

  • 1. ТЕХНОЛОГИЯ ПРОГРАММИРОВАНИЯ. ОСНОВНЫЕ ПОНЯТИЯ И ПОДХОДЫ

  • Первый этап - «стихийное» программирование.

  • Учебник Технология программирования. Технология программирования


    Скачать 7.85 Mb.
    НазваниеТехнология программирования
    АнкорУчебник Технология программирования.pdf
    Дата04.05.2017
    Размер7.85 Mb.
    Формат файлаpdf
    Имя файлаУчебник Технология программирования.pdf
    ТипДокументы
    #6946
    КатегорияИнформатика. Вычислительная техника
    страница1 из 27
      1   2   3   4   5   6   7   8   9   ...   27

    3
    Г.С. ИВАНОВА
    ТЕХНОЛОГИЯ ПРОГРАММИРОВАНИЯ
    Издание второе, стереотипное
    Допущено Министерством образования
    Российской Федерации
    в качестве учебника для студентов
    высших учебных заведений, обучающихся по направлению
    «Информатика и вычислительная техника»,
    специальностям: «Вычислительные машины, комплексы,
    системы и сети», «Автоматизированные системы обработки
    информации и управления», «Программное обеспечение
    вычислительной техники и информационных систем»
    Москва
    Издательство МГТУ имени Н.Э. Баумана 2003

    4
    УДК 681.3.06(075.8) ББК 32.973-018 И201
    Рецензенты: кафедра «Компьютерные системы и технологии»
    Московского государственного инженерно-физического института
    (зав. кафедрой профессор Л.Д. Забродин); кафедра «ЭВМ, комплексы и сети»
    Московского государственного авиационного института
    (зав. кафедрой профессор О.М. Брехов)
    Иванова Г.С.
    И201 Технология программирования: Учебник для вузов. - 2-е изд., стереотип. - М.: Изд-во МГТУ им. Н.Э.
    Баумана, 2003. - 320 с.: ил. (Сер. Информатика в техническом университете.)
    ISBN 5-7038-2077-4
    Подробно рассмотрены основные методы и нотации, применяемые при разработке сложного программного обеспечении. При этом особое внимание уделено проектированию программных систем с использованием структурного, объектного и компонентного подходов. Детально разобраны основные приемы обеспечения требуемых технологических свойств.
    Приведена классификация и проанализированы принципы проектирования пользовательских интерфейсов программного обеспечения. Изложение материала иллюстрируется большим количеством примеров и поясняющих рисунков.
    Содержание учебника соответствует курсу лекций, который автор читает в МГТУ им. Н.Э. Баумана.
    Для студентов вузов, обучающихся по специальностям, связанным с информатикой. Может быть полезен всем изучающим программирование самостоятельно.
    УДК 681.3.06(075.8) ББК 32.973-018
    © Г.С. Иванова, 2002
    ISBN 5-7038-2077-4
    (
    с
    )
    МГТУ им. Н.Э. Баумана. 2002

    5
    Оглавление
    Предисловие ......................................................................................…………….9
    Введение ............................................................................................……………10
    1. Технология программирования. Основные понятия и подходы………..12
    1.1.Технология программирования и основные этапы ее развития ……….....12 1.2.Проблемы разработки сложных программных систем…………………….23 1.3.Блочно-иерархический подход к созданию сложных систем ……………..24 1.4.Жизненный цикл и этапы разработки программного обеспечения………..27 1.5.Эволюция моделей жизненного цикла программного обеспечения……….32 1.6.Ускорение разработки программного обеспечения. Технология RAD……37 1.7.Оценка качества процессов создания программного обеспечения………...40
    2. Приемы обеспечения технологичности программных продуктов………..45
    2.1.Понятие технологичности программного обеспечения……………………..45 2.2.Модули и их свойства .................................................................. ……………..46 2.3.Нисходящая и восходящая разработка программного обеспечения ………55 2.4.Структурное и «неструктурное» программирование. Средства описания структурных алгоритмов............................................. …………….57 2.5.Стиль оформления программы ................................................... …………….65 2.6.Эффективность и технологичность ........................................... …………….68 2.7.Программирование «с защитой от ошибок» ............................ …………….70 2.8.Сквозной структурный контроль ............................................... …………….73

    6
    3. Определение требований к программному обеспечению и исходных
    данных для его проектирования .................................................…………………75
    3.1.Классификация программных продуктов по функциональному признаку ……75 3.2.Основные эксплуатационные требования к программным продуктам……........78 3.3.Предпроектные исследования предметной области.................. …………………81 3.4.Разработка технического задания ............................................... …………………82 3.5.Принципиальные решения начальных этапов проектирования ………………..95
    4. Анализ требований и определение спецификаций программного
    обеспечения при структурном подходе........................................………………….103
    4.1.Спецификации программного обеспечения при структурном подходе…….......103 4.2.Диаграммы переходов состояний ..............................................………………….107 4.3.Функциональные диаграммы......................................................………………….109 4.4.Диаграммы потоков данных........................................................………………….114 4.5.Структуры данных и диаграммы отношений компонентов данных……………123 4.6.Математические модели задач, разработка или выбор методов решения……...136
    5. Проектирование программного обеспечения при структурном подходе………139
    5.1.Разработка структурной и функциональной схем ....................……………………139 5.2.Использование метода пошаговой детализации для проектирования структуры программного обеспечения ......................................……………………143 5.3.Структурные карты Константайна .............................................…………………….149 5.4.Проектирование структур данных..............................................…………………….154 5.5.Проектирование программного обеспечения, основанное на декомпозиции данных ..................................................................…………………….159 5.6.Case-технологии, основанные на структурных методологиях анализа и проектирования..........................................................................…………………….164
    6. Анализ требований и определение спецификаций программного
    обеспечения при объектном подходе ...........................................…………………….167

    7 6.1. UML
    — стандартный язык описания разработки программных продуктов с использованием объектного подхода .....................................…………………..167 6.2.Определение «вариантов использования».................................…………………..170 6.3.Построение концептуальной модели предметной области .....…………………..176 6.4.Описание поведения. Системные события и операции ......... …………………..182 7. Проектирование программного обеспечения при объектном подходе .…….............188 7.1. Разработка структуры программного обеспечения при объектном подходе ...................................................................................... ……………………188 7.2.Определение отношений между объектами ............................ ……………………191 7.3.Уточнение отношений классов ................................................. ……………………197 7.4.Проектирование классов ........................................................... ……………………201 7.5.Компоновка программных компонентов ................................. ……………………208 7.6.Проектирование размещения программных компонентов для распределенных программных систем .............................. ……………………211 7.7. Особенность спиральной модели разработки. Реорганизация проекта .…………212 8. Разработка пользовательских интерфейсов ................................... ……………………214 8.1.Типы пользовательских интерфейсов и этапы их разработки……………………..214 8.2.Психофизические особенности человека, связанные с восприятием, запоминанием и обработкой информации ................................ ……………………224 8.3.Пользовательская и программная модели интерфейса ........... ……………………227 8.4.Классификации диалогов и общие принципы их разработки……………………..230 8.5.Основные компоненты графических пользовательских интерфейсов ..……........237 8.6.Реализация диалогов в графическом пользовательском интерфейсе…………….241 8.7.Пользовательские интерфейсы прямого манипулирования и их проектирование.................................................................... ……………………251 8.8. Интеллектуальные элементы пользовательских интерфейсов…………………...259

    8
    9. Тестирование программных продуктов ....................................…………………..263
    9.1.Виды контроля качества разрабатываемого программного обеспечения…….....263 9.2.Ручной контроль программного обеспечения.......................... …………………..265 9.3.Структурное тестирование ..........................................................…………………..269 9.4.Функциональное тестирование...................................................…………………..273 9.5.Тестирования модулей и комплексное тестирование...............…………………..279 9.6.Оценочное тестирование ............................................................ …………………..284
    10. Отладка программного обеспечения ..................................... …………………..287
    10.1.Классификация ошибок............................................................ …………………..287 10.2.Методы отладки программного обеспечения ....................... …………………..291 10.3.Методы и средства получения дополнительной информации …………………294 10.4.Общая методика отладки программного обеспечения .........…………………..297
    11.Составление программной документации ...............................…………………..300
    11.1.Виды программных документов .............................................…………………..300 11.2.Пояснительная записка ........................................................... …………………..302 11.3.Руководство пользователя ...................................................... …………………..303 11.4.Руководство системного программиста ................................. …………………..304 11.5.Основные правила оформления программной документации ………………...305 11.6.Правила оформления расчетно-пояснительных записок при курсовом проектировании ......................................................................... …………………..308
    Приложение. Система условных обозначений унифицированного языка моделирования UML...........................................…………………...311
    Список литературы ....................................................................... ……………………315
    Предметный указатель .................................................................. ……………………318

    9
    К175-летию МГТУ имени Н.Э. Баумана
    ПРЕДИСЛОВИЕ
    До последнего времени элементы технологии разработки программного обеспечения студенты изучали в таких курсах, как «Алгоритмические языки и программирование» и
    «Системное программирование», параллельно с основным материалом, что не позволяло сконцентрироваться на указанных вопросах. Однако сравнительно недавно в учебных планах специальностей, связанных с информатикой, появился курс «Технология программирования», полностью посвященный этой теме. В предлагаемом учебнике сделана попытка обобщения и методического осмысления опыта, накопленного специалистами в области разработки программного обеспечения на протяжении всей истории существования.
    Приведенные сведения могут быть полезны при выполнении учебных проектов и небольших программных продуктов.
    В создании данного учебника в той или иной степени участвовало много заинтересованных лиц. Хочется от души поблагодарить: редактора издательства Овчеренко
    Н.Е., поддержавшую идею написания данной книги; заведующих кафедрами
    «Компьютерные системы и сети» Сюзева В.В. и «Программирования и информационные технологии» Трусова Б.Г. – за всестороннее содействие; моего мужа – профессора кафедры
    «Компьютерные системы и сети» Овчинникова В.А. – за помощь и поддержку; преподавателей университета: Борисова С.В., Курова А.В. – за предоставленную литературу изданий прошлых лет; Романову Т.Н., Пугачева Е.К., Ничушкину Т.Н., Волосатову Т.М. и
    Балдина А.В – за материалы и советы по содержанию учебника. Автор также глубоко признательна рецензентам: коллективу кафедры «Компьютерные системы и технологии»
    МИФИ во главе с д-ром техн. наук, профессором Забродиным Л.Д. и коллективу кафедры
    «ЭВМ, комплексы и сети» МАИ во главе с д-ром техн. наук, профессором Бреховым О.М., чьи ценные замечания позволили улучшить качество книги.

    10
    ВВЕДЕНИЕ
    Создание программной системы – весьма трудоемкая задача, особенно в наше время, когда обычный объем программного обеспечения превышает сотни тысяч операторов.
    Будущий специалист в области разработки программного обеспечения должен иметь представление о методах анализа, проектирования, реализации и тестирования программных систем, а также ориентироваться в существующих подходах и технологиях.
    Изложение материала учебника строится в соответствии с основными этапами разработки программного обеспечения. Исключением являются первые главы, в которых рассмотрены общие вопросы технологии программирования.
    В первой главе проанализирована история развития технологии программирования, показано, что в основе разработки программного обеспечения лежит блочно-иерархический подход, рассмотрены особенности применения этого подхода к разработке программных продуктов.
    Вторая глава содержит описание приемов обеспечения качества программного обеспечения: основных положений структурного, модульного и защитного программирования. В ней также приведены некоторые рекомендации, например, по стилю оформления программ.
    В третьей главе рассматриваются проблемы, связанные с постановкой задачи: от классификации программных продуктов до разработки технического задания и принятия основных решений начального этапа проектирования, например, выбора подхода, среды и языка программирования.
    Четвертая и пятая главы посвящены особенностям разработки программного обеспечения при структурном подходе; четвертая – анализу различных моделей разрабатываемого программного обеспечения, используемых на этапе уточнения спецификаций, а пятая - методикам проектирования.
    Шестая и седьмая главы содержат аналогичный материал для объектного подхода. В качестве основного языка описания моделей анализа и проектирования при объектном подходе используется UML, как мощное и практически стандартное средство описания объектных разработок.

    11
    В восьмой главе подробно рассмотрены проблемы проектирования пользовательского интерфейса и предлагаются соответствующие модели.
    Девятая глава посвящена тестированию программных продуктов как по частям, так и в целом, десятая – методам, средствам и методикам отладки разрабатываемого программного обеспечения.
    В одиннадцатой главе приведены сведения и рекомендации по разработке программной документации.
    Материал сопровождается большим количеством сравнительно простых примеров, причем по возможности использованы три примера разработки, для которых рассмотрены различные аспекты проектирования.
    Курс обучения целесообразно завершать курсовым проектом или курсовой работой, целью которых должно быть создание небольшого, но завершенного программного продукта
    (в отличие от небольших и, как правило, недокументированных программ, которые студенты пишут на лабораторных работах при изучении основ программирования и/или конкретных языков). Проект должен начинаться с составления и утверждения технического задания и сопровождаться подготовкой необходимой программной документации.

    12
    1. ТЕХНОЛОГИЯ ПРОГРАММИРОВАНИЯ.
    ОСНОВНЫЕ ПОНЯТИЯ И ПОДХОДЫ
    Программирование

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

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

    перечисление условий, при которых выполняется та или иная операция;

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

    13
    деляющий совокупность методов, используемых на разных этапах разработки, или
    методологию.
    Чтобы разобраться в существующих технологиях программирования и определить основные тенденции их развития, целесообразно рассматривать эти технологии в историческом контексте, выделяя основные этапы развития программирования, как науки.
    Первый этап - «стихийное» программирование. Этот этап охватывает период от момента появления первых вычислительных машин до середины 60-х годов XX в. В этот период практически отсутствовали сформулированные технологии, и программирование фактически было искусством. Первые программы имели простейшую структуру. Они состояли из собственно программы на машинном языке и обрабатываемых ею данных (рис.
    1.2). Сложность программ в машинных кодах ограничивалась способностью программиста одновременно мысленно отслеживать последовательность выполняемых операций и местонахождение данных при программировании.
    Появление ассемблеров позволило вместо двоичных или 16-ричных кодов использовать символические имена данных и мнемоники кодов операций. В результате программы стали более «читаемыми».
    Создание языков программирования высокого уровня, таких, как
    FORTRAN и ALGOL, существенно упростило программирование вычислений, снизив уровень детализации операций. Это, в свою очередь, позволило увеличить сложность программ.
    Революционным было появление в языках средств, позволяющих оперировать подпрограммами. (Идея написания подпрограмм появилась

    14
    гораздо раньше, но отсутствие средств поддержки в первых языковых средствах существенно снижало эффективность их применения.) Подпрограммы можно было сохранять и использовать в других программах. В результате были созданы огромные библиотеки расчетных и служебных подпрограмм, которые по мере надобности вызывались из разрабатываемой программы.
    Типичная программа того времени состояла из основной программы, области глобальных данных и набора подпрограмм (в основном библиотечных), выполняющих обработку всех данных или их части (рис. 1.3). Слабым местом такой архитектуры было то, что при увеличении количества подпрограмм возрастала вероятность искажения части глобальных данных какой-либо подпрограммой. Например, подпрограмма поиска корней уравнения на заданном интервале по методу деления отрезка пополам меняет величину интервала. Если при выходе из подпрограммы не предусмотреть восстановления первоначального интервала, то в глобальной области окажется неверное значение интервала.
    Чтобы сократить количество таких ошибок, было предложено в подпрограммах размещать
    локальные данные (рис. 1.4).
    Сложность разрабатываемого программного обеспечения при использовании подпрограмм с локальными данными по-прежнему ограничивалась возможностью программиста отслеживать процессы обработки данных, но уже на новом уровне. Однако появление средств поддержки подпрограмм позволило осуществлять разработку программного обеспечения нескольким программистам параллельно.
    В начале 60-х годов XX в. разразился «кризис программирования». Он выражался в том, что фирмы, взявшиеся за разработку сложного программного обеспечения, такого, как операционные системы, срывали все сроки завершения проектов [8]. Проект устаревал

    15
    раньше, чем был готов к внедрению, увеличивалась его стоимость, и в результате многие проекты так никогда и не были завершены.
    Объективно все это было вызвано несовершенством технологии программирования. Прежде всего стихийно использовалась разработка «снизу-вверх»
    - подход, при котором вначале проектировали и реализовывали сравнительно простые подпрограммы, из которых затем пытались построить сложную программу. В отсутствии четких моделей описания подпрограмм и методов их проектирования создание каждой подпрограммы превращалось в непростую задачу, интерфейсы подпрограмм получались сложными, и при сборке программного продукта выявлялось большое количество ошибок согласования. Исправление таких ошибок, как правило, требовало серьезного изменения уже разработанных подпрограмм, что еще более осложняло ситуацию, так как при этом в программу часто вносились новые ошибки, которые также необходимо было исправлять... В конечном итоге процесс тестирования и отладки программ занимал более 80 % времени разработки, если вообще когда-нибудь заканчивался. На повестке дня самым серьезным образом стоял вопрос разработки технологии создания сложных программных продуктов, снижающей вероятность ошибок проектирования.
    Анализ причин возникновения большинства ошибок позволил сформулировать новый подход к программированию, который был назван «структурным» [19, 23].
      1   2   3   4   5   6   7   8   9   ...   27


    написать администратору сайта