Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Текст лекций.doc
Скачиваний:
3
Добавлен:
01.04.2025
Размер:
1.59 Mб
Скачать

5.4. Правила записи трассировки

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

  1. В качестве результатов операций ввода и присваивания записываются новые значения переменных (в виде тождеств).

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

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

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

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

  6. Трассировка должна быть прекращена только по достижении строки «конец» алгоритма.

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

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

Дано: {a=2, b=0, x=4}

Требуется: {x=3}

Трассировка:

{ {2>1}да и {0=0}да }да

x = 2

{ {2=2}да и {2>1}да }да

x = 3

Конец.

Вывод: Полученный результат (x=3) совпадает с эталонным. Ошибки нет.

Вопросы для самоконтроля

  1. Что такое «тест»? Каково его назначение?

  2. Какой тест является хорошим и какой плохим?

  3. Сколько тестов требуется для получения уверенности, что программа работает правильно?

  4. Дайте качественное определение термина «система тестов».

  5. Перечислите виды тестирования?

  6. Какой вид тестирования более удобен на этапе разработки программы?

  7. Что понимается под стратегией тестирования?

  8. В чем отличия стратегий «черного ящика» и «белого ящика»?

  9. Что понимается под классом эквивалентности?

  10. Какие критерии используются при выделении классов эквивалентности?

  11. В чем суть метода граничных условий?

  12. Перечислите и вкратце охарактеризуйте методы стратегии «белого ящика».

  13. В чем отличия методов покрытия решений и покрытия условий?

  14. Что понимается под термином «трассировка»?

  15. Перечислите правила записи трассировки?

6. Характеристики качества программы

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

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

Frame91

Основная идея алгоритма заключается в следующем: если число N не будет делиться без остатка ни на одно из чисел натурального ряда, меньшее чем N, то оно, согласно определению, будет простым.

Приведенная программа написана на языке Паскаль и имеет имя Simple.

В разделе описаний объявлены следующие переменные:

N – типа целых – исходное (проверяемое) число

I – типа целых – возможный делитель (параметр цикла)

F – логический (булевский) тип – признак «делитель найден».

Последовательность действий в программе следующая:

Вводим число N. Присваиваем признаку F значение “ложь”. В цикле просматриваем все возможные делители. Если остаток от деления равен нулю, устанавливаем признаку F значение «истина».

Наконец, анализируем значение признака F и выводим результат в виде строки текста.

Рассмотрим, отвечает ли наша программа критериям качества.

Корректность (правильность) - это строгое и полное соответствие конечных результатов выполнения программы требованиям постановки задачи.

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

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

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

Чтобы избавиться от этой ошибки, введем контроль введенного значения и завершение работы программы в случае ошибки. Текст программы с указанными изменениями теперь выглядит так:

Frame92

Теперь программа будет функционировать надежнее.

Удобство применения – это способность программы обеспечивать простоту ввода исходных данных и получение результатов в наиболее понятной и наглядной форме.

Для этого программа должна:

  • формировать запрос на ввод данных в понятной форме

  • снабжать комментариями вывод результатов

  • информировать пользователя об ошибках при задании входных данных и (при диалоговом режиме работы программы) дать ему возможность исправить ошибку.

Наша программа (ее вторая версия):

  • не выводит запрос на ввод данных

  • не информирует об ошибке (при вводе отрицательного числа)

  • не позволяет исправить эту ошибку.

Исправим программу следующим образом:

Вместо оператора «goto LabErr» используем конструкцию «repeat … until», обеспечив повторение запроса на ввод данных до тех пор, пока они не будут введены правильно. Кроме этого дополнительно поместим операторы вывода сообщения о назначении программы.

Теперь текст программы примет следующий вид:

Frame93

Эффективность по быстродействию и по затратам памяти характеризуется зависимостью времени работы программы или затрат основной памяти от размера исходных данных. В этом контексте говорят о временнóй (ударение на «о») и емкостной сложности программы.

Поведение временнóй сложности в пределе при увеличении размера задачи называется асимптотической временнóй сложностью программы.

Зависимости могут быть различными, например:

  • линейными, когда временнáя сложность линейно зависит от N (например, при вычислении суммы элементов массива)

  • квадратичными, когда временнáя сложность имеет порядок N2 (например, при сортировке массива)

  • логарифмическими, когда время решения пропорционально log2N (например, при поиске в упорядоченном массива методом деления интервала пополам).

Асимптотическая временнáя сложность – важная характеристика алгоритма и программы, построенной на ее основе. Выбор более оптимального алгоритма, если это в принципе возможно, с меньшей асимптотической временнóй сложностью позволит значительно сократить время работы программы.

В нашей программе асимптотическая временнáя сложность – линейная (за счет использования цикла со счетчиком «for I:=2 to N-1 do». Однако можно заметить, что для поиска делителя достаточно просмотреть числа от 2 до корня квадратного от N, и в этом случае асимптотическая временнáя сложность программы уменьшится и станет пропорциональной корню квадратному от N. При этом вместо приведенного выше оператора цикла потребуется два:

imax:=round(sqrt(N));

for I:=2 to imax do

Кроме того, время работы программы можно сократить еще, если прекращать выполнение цикла, как только будет найден первый делитель. Для этого заменим оператор цикла со счетчиком (for) на оператор цикла с предусловием (while).

Текст новой (четвертой) версии программы примет следующий вид:

Frame94

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

Удобство сопровождения - это способность программы обеспечивать простоту процесса поддержания программы (программного обеспечения) в работоспособном состоянии и простоту внесения в нее необходимых модификаций.

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

Для простоты сопровождения требуется:

  • Структурированность программы

  • Наличие комментариев в тексте программы

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

Структурированность программы достигается за счет выполнения следующих требований к ее записи:

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

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

В нашем случае программа структурирована только частично. В ней нарушены правила ступенчатой записи конструкции «если» в теле цикла repeat . . until и в конце программы.

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

Текст программы (версия 5), после внесения в него изменений, примет вид, удовлетворяющей рассмотренным выше критериям. Он приведен на следующей странице.

Мобильность универсальность) – это возможность перенесения программного обеспечения с одного типа ЭВМ на другой или с одной платформы (операционной среды) на другую.

Наша программа построена с использованием версии языка Паскаль, соответствующей стандарту ISO (Международной организации стандартов), и поэтому она может быть легко перенесена в другие операционные среды и на другие типы ЭВМ