
- •30. Понятие архитектуры программного средства. Классы архитектур. Архитектурные функции. Контроль архитектуры.
- •Задача разработки архитектуры по.
- •Основные классы архитектур.
- •Архитектурные функции.
- •Контроль архитектуры программных средств.
- •31. Понятие качества программного средства. Обеспечение надежности. Методы борьбы со сложностью. Понятие качества программного средства.
- •Обеспечение надежности – основной мотив разработки программных средств.
- •Методы борьбы со сложностью.
- •32. Принципы («заповеди») отладки программных средств.
- •Принципы отладки программного средства.
- •Принципы данной стратегии.
- •2 Основных вида отладки пс:
- •Правила отладки пс.
- •Правила по организации отладки:
- •33. Специфика разработки программных средств. Специфика разработки пс:
- •Жизненный цикл программного средства.
- •34. Спецификация качества программного средства.
- •Критерии качества:
- •35. Структурная методология разработки программ. Основные понятия и определения. Модули, модульное программирование.
- •Парадигма программирования.
- •36. Структурная методология разработки программ. Принципы и стандарты структурного программирования.
- •Парадигма программирования.
- •37. Тестирование и отладка программной системы. Основные определения. Виды отладки и тестирования.
- •Принципы отладки программного средства.
- •Принципы данной стратегии.
- •2 Основных вида отладки пс:
- •Комплексная отладка по.
- •Автономная отладка программной системы.
- •38. Управление разработкой и аттестация программной системы. Виды аттестаций.
- •Аттестации программного средства.
- •39. Управление разработкой и аттестация программной системы. Назначение и процессы управления разработкой.
- •Структура управления разработкой программных средств.
- •Программные стандарты по.
- •Управление обеспечения качеством.
- •40.Функциональная спецификация программного средства.
- •Функциональная спецификация состоит из трех частей:
Методы борьбы со сложностью.
Известны два общих метода борьбы со сложностью систем: обеспечения независимости компонент системы, использование в системах иерархических структур.
Обеспечение независимости компонент означает разбиение системы на такие части, между которыми должны остаться по возможности меньше связей. Одним из воплощений этого метода является модульное программирование. Использование в системах иерархических структур позволяет локализовать связи между компонентами, допуская их лишь между компонентами, принадлежащими смежным уровням иерархии. Этот метод, по существу, означает разбиение большой системы на подсистемы, образующих малую систему. Здесь существенно используется способность человека к абстрагированию.
32. Принципы («заповеди») отладки программных средств.
Отладка ПОэто деятельность, направленная на обнаружение и исправление ошибок в ПО с использованием процессов выполнения его программ.Тестирование ПОэто процесс выполнения его программ на некотором наборе данных, для которого заранее известен результат применения или известны правила поведения этих программ. Указанный набор данных называетсятестовымили простотестом. Таким образом, отладку можно представить в виде многократного повторения трех процессов: тестирования, в результате которого может быть констатировано наличие в ПО ошибки, поиска места ошибки в программах и документации ПО и редактирования программ и документации с целью устранения обнаруженной ошибки. Другими словами:
Отладка = Тестирование + Поиск ошибок + Редактирование.
Принципы отладки программного средства.
Успех отладки ПО в значительной степени предопределяет рациональная организация тестирования. При отладке ПО отыскиваются и устраняются, в основном, те ошибки, наличие которых в ПО устанавливается при тестировании. Другими словами, нельзя гарантировать, что тестированием ПО практически выполнимым набором тестов можно установить наличие каждой имеющейся в ПО ошибки. Поэтому возникает две задачи. Первая задача: подготовить такой набор тестов и применить к ним ПО, чтобы обнаружить в нем по возможности большее число ошибок. Однако чем дольше продолжается процесс тестирования (и отладки в целом), тем большей становится стоимость ПО. Отсюдавторая задача: определить момент окончания отладки ПО (или отдельной его компоненты). Признаком возможности окончания отладки является полнота охвата пропущенными через ПО тестами (т.е. тестами, к которым применено ПО) множества различных ситуаций, возникающих при выполнении программ ПО, и относительно редкое проявление ошибок в ПО на последнем отрезке процесса тестирования. Последнее определяется в соответствии с требуемой степенью надежности ПО, указанной в спецификации его качества.
Для оптимизации набора тестов, т.е. для подготовки такого набора тестов, который позволял бы при заданном их числе (или при заданном интервале времени, отведенном на тестирование) обнаруживать большее число ошибок в ПО, необходимо, во-первых, заранее планировать этот набор и, во-вторых, использовать рациональную стратегию планирования. Проектирование тестов можно начинать сразу же после завершения этапа внешнего описания ПО. Возможны разные подходы к выработке стратегии проектирования тестов. Левый крайний подходзаключается в том, что тесты проектируются только на основании изучения спецификаций ПО (внешнего описания, описания архитектуры и спецификации модулей). Строение модулей при этом никак не учитывается, т.е. они рассматриваются как черные ящики.Правый крайний подходзаключается в том, что тесты проектируются на основании изучения текстов программ с целью протестировать все пути выполнения каждой программ ПО. Если принять во внимание наличие в программах циклов с переменным числом повторений, то различных путей выполнения программ ПО может оказаться также чрезвычайно много, так что их тестирование также будет практически неосуществимо.
Поэтому оптимальная стратегия проектирования нечто среднее м/у ними, но ближе к тестированию по спецификации, т.е. включает значительную часть тестов по спецификациям и требует проектирование отдельных тестов по архитектуре программ.