- •Вопрос 1: Технологии конструирования программ. Основные определения и понятия.
- •Вопрос 2: Основные характеристики программных продуктов.
- •Вопрос 3) Классы программых продуктов
- •Вопрос 5) Жизненный цикл программных средств.
- •Вопрос 6: Стратегии конструирования по
- •Вопрос 7: Критерии качества программ по стандартам iso (гост р исо/мэк 9126-93) показатели качества по (iso8402 1994г.)
- •Вопрос 8: Модель смм.
- •Вопрос 9: Методологии проектирования по. Case-технологии, их содержание и классификации
- •Вопрос 10) case-средства. Общая характеристика и классификация
- •Вопрос 11: Размерно-ориентированные метрики
- •Вопрос 12) Метрики сложности
- •Вопрос 13) Документирование программ
- •Вопрос 14) Оптимизация программ
- •Вопрос 15) Отладка и тестирование программ
- •Вопрос 16: Источники и классификация ошибок. Классификация ошибок
- •Вопрос 17) Объектно-ориентированное проектирование
- •Классификация ошибок
- •Предотвращение и обработка ошибок
- •Вопрос 18) Язык uml Базис языка визуального моделирования
- •Унифицированный язык моделирования
- •Предметы в uml
- •Отношения в uml
- •Диаграммы в uml
- •Механизмы расширения в uml
- •Терминология языка uml и унифицированного процесса
- •Вопрос 19: Современные технологии проектирования приложений.
Классификация ошибок
Ошибки, которые могут быть в программе, принято делить на три группы:
синтаксические;
ошибки времени выполнения;
алгоритмические.
Синтаксические ошибки, их также называют ошибками времени компиляции (Compile-time error), наиболее легко устранимы. Их обнаруживает компилятор, а программисту остается только внести изменения в текст программы и выполнить повторную компиляцию.
Ошибки времени выполнения, в Delphi они называются исключениями (exception), тоже, как правило, легко устранимы. Они обычно проявляются уже при первых запусках программы и во время тестирования.
При возникновении ошибки в программе, запущенной из Delphi, среда разработки прерывает работу программы, о чем свидетельствует заключенное в скобки слово Stopped в заголовке главного окна Delphi, и на экране появляется диалоговое окно, которое содержит сообщение об ошибке и информацию о типе (классе) ошибки. На рис. 13.1 приведен пример сообщения об ошибке, возникающей при попытке открыть несуществующий файл.
После возникновения ошибки программист может либо прервать выполнение программы, для этого надо из менюRun выбрать команду Program Reset, либо продолжить ее выполнение, например, по шагам (для этого из менюRun надо выбрать команду Step), наблюдая результат выполнения каждой инструкции.
Рис. 13.1. Сообщение об ошибке при запуске программы из Delphi
Если программа запущена из Windows, то при возникновении ошибки на экране также появляется сообщение об ошибке, но тип ошибки (исключения) в сообщении не указывается (рис. 13.2). После щелчка на кнопке ОКпрограмма, в которой проявилась ошибка, продолжает (если сможет) работу.
Рис. 13.2. Сообщение об ошибке при запуске программы из Windows
С алгоритмическими ошибками дело обстоит иначе. Компиляция программы, в которой есть алгоритмическая ошибка, завершается успешно. При пробных запусках программа ведет себя нормально, однако при анализе результата выясняется, что он неверный. Для того чтобы устранить алгоритмическую ошибку," приходится анализировать алгоритм, вручную "прокручивать" его выполнение.
Предотвращение и обработка ошибок
Как было сказано выше, в программе во время ее работы могут возникать ошибки, причиной которых, как правило, являются действия пользователя. Например, пользователь может ввести неверные данные или, что бывает довольно часто, удалить нужный программе файл.
Нарушение в работе программы называется исключением. Обработку исключений (ошибок) берет на себя автоматически добавляемый в выполняемую программу код, который обеспечивает, в том числе, вывод информационного сообщения. Вместе с тем Delphi дает возможность программе самой выполнить обработку исключения.
Инструкция обработки исключения в общем виде выглядит так:
try
// здесь инструкции, выполнение которых может вызвать исключение
except // начало секции обработки исключений
on ТипИсключения1 do Обработка1;
on ТипИсключения2 do Обработка2;
on ТипИсключенияJ do ОбработкаJ;
else
// здесь инструкции обработки остальных исключений
end;
где:
try — ключевое слово, обозначающее, что далее следуют инструкции, при выполнении которых возможно возникновение исключений, и что обработку этих исключений берет на себя программа;
except — ключевое слово, обозначающее начало секции обработки исключений. Инструкции этой секции будут выполнены, если в программе возникнет ошибка;
on — ключевое слово, за которым следует тип исключения, обработку которого выполняет инструкция, следующая за do;
else — ключевое слово, за которым следуют инструкции, обеспечивающие обработку исключений, тип которых не указаны в секции except.
Как было сказано выше, основной характеристикой исключения является его тип. В таблице 13.1 перечислены наиболее часто возникающие исключения и указаны причины, которые могут привести к их возникновению.
Таблица 13.1. Типичные исключения
|
|
|
|
|
Тип исключения |
Возникает |
|
|
EZeroDivide |
При выполнении операции деления, если делитель равен нулю |
|
|
EConvertError |
При выполнении преобразования, если преобразуемая величина не может быть приведена к требуемому виду. Наиболее часто возникает при преобразовании строки символов в число |
|
|
|
|
|
|
|
|
|
|
Тип исключения |
Возникает |
|
|
EFilerError |
При обращении к файлу. Наиболее частой причиной является отсутствие требуемого файла или, в случае использования сменного диска, отсутствие диска в накопителе |
|
|
|
|
|
Ошибки выполнения:
Определения данных;
Передачи;
Преобразования;
Перезаписи;
Неправильные данные.
Логические;
Неприемлемый подход;
Неверный алгоритм;
Неверная структура данных;
Другие;
Кодирования;
Проектирования;
Некорректная работа с переменными;
Некорректные вычисления;
Ошибки интерфейсов;
Неправильная реализация алгоритма;
Другие.
Накопления погрешностей;
Игнорирование ограничений разрядной сетки;
Игнорирование способов уменьшения погрешностей.