Функции, помещаемые в библиотеку *.dll

      Комментарии к записи Функции, помещаемые в библиотеку *.dll отключены

Таблица 6.1

№ варианта № функций № варианта № функций № варианта № функций
1, 15 5, 12 1, 10
2, 14 6, 11 2, 9
3, 12 7, 10 3, 8
4, 11 8, 9 4, 7
5, 10 3, 15 5, 6
6, 9 4, 14 2, 13
7, 8 5, 13 3, 12
2, 15 6, 12 4, 11
3, 14 7, 11 5, 10
4, 13 8, 10 6, 9

Лабораторная работа № 7

Обработка исключительных ситуаций в Visual C#

7.1. Цель работы

Ознакомление с классом исключительных ситуаций Visual C# и выработ- ка навыков создания приложений, осуществляющих обработку возникающих исключительных ситуаций

7.2. Теоретические сведения

Любое взаимодействие программы с операционной системой (ОС) на предмет получения ее ресурсов (открытия файла, места в оперативной памяти и т.п.) может окончиться неудачно. Выполнение любого вычисления может окончиться делением на нуль или переполнением. Платой за надежную работу программы в таких условиях является введение многочисленных проверок, га- рантирующих надежную работу программы при возникновении внештатных ситуаций. Как правило, бывает недостаточно просто в очередной конструкции условного перехода (типа if… then) поставить оператор выхода exit, а требу- ется отменить целую последовательность действий, предшествующих некор- ректному. Код программы, осуществляющий эти действия, будет маскировать четкую структуру главного алгоритма и приводить к ухудшению читабельности программы. Выход из данной ситуации был предложен разработчиками ОС Windows NT и получил название структурной обработки исключительных си- туаций (ИС). Позднее его поддержка была введена во все ОС, а также в среды разработки программ.

Исключительная ситуация, или исключение, — это возникновение аварий- ного события, которое может порождаться некорректным использованием ап-

паратуры или неправильной работой программы, например делением на ноль или переполнением. Обычно эти события приводят к завершению программы с системным сообщением об ошибке. С# дает программисту возможность вос- становить работоспособность программы и продолжить ее выполнение. Ис- ключения С# не поддерживают обработку асинхронных событий, таких как ошибки оборудования или прерывания, например нажатия клавиш Ctrl^C. Ме- ханизм исключений предназначен только для событий, которые могут произой-

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

Исключения позволяют логически разделить вычислительный процесс на две части – обнаружение аварийной ситуации и ее обработку. Это важно не

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

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

Исключения генерирует либо среда выполнения, либо программист с по-

мощью оператора throw. Наиболее часто используемые предопределенные ис- ключительные ситуации в C# следующие:

ArithmeticException – ошибка в арифметических операциях или преобразованиях (является предком DivideByZeroException и OverFlo- wException);

ArrayTypeMismatchException – попытка сохранения в массиве элемента несовместимого типа;

DivideByZeroException – попытка деления на ноль;

FormatException – попытка передать в метод аргумент неверного формата;

IndexOutOfRangeException – индекс массива выходит за границы диапазона;

InvalidCasrException – ошибка преобразования типа;

OutOfMemoryException – недостаточно памяти для создания нового объекта;

OverFlowException – переполнение при выполнении арифметических операций;

StackOverFlowException – переполнение стека.

Все перечисленные исключения определены в пространстве имен System. Все они являются потомками класса SystemException. Исключе- ния обнаруживаются и обрабатываются оператором try, который имеет сле- дующий синтаксис:

try блок [блоки catch] [блок finally]

Отсутствовать могут либо блоки catch, либо блок finally, но не оба

одновременно. Оператор try содержит три части:

1) контролируемый блок – составной оператор, предваряемый ключе-

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

2) один или несколько обработчиков исключений — блоков catch, в которых описывается, как обрабатываются ошибки различных типов.

3) блок завершения finally выполняется независимо от того, возникла ошибка в контролируемом блоке или нет.

Алгоритм обработки исключения выглядит следующим образом:

1. Обработка исключения начинается с появления ошибки. Функция или операция, в которой возникла ошибка, генерирует исключение. Как правило,

исключение генерируется не непосредственно в блоке try, а в функциях, пря- мо или косвенно в него вложенных.

2. Выполнение текущего блока прекращается, отыскивается соответст- вующий обработчик исключения и ему передается управление.

3. Выполняется блок finally, если он присутствует (этот блок выпол- няется и в том случае, если ошибка не возникла).

4. Если обработчик не найден, вызывается стандартный обработчик ис-

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

Обработчики исключений должны располагаться непосредственно за

блоком try. Они начинаются с ключевого слова catch, за которым следует в скобках тип обрабатываемого исключения. Можно записать один или несколь- ко обработчиков в соответствии с типами обрабатываемых исключений. Блоки catch просматриваются в том порядке, в котором они записаны, пока не будет найден соответствующий типу сгенерированного исключения. Существуют три формы записи обработчиков catch:

catch (тип имя) { …// тело обработчика} catch (тип) {… // тело обработчика} catch () {… // тело обработчика}

Первая форма применяется, когда имя параметра используется в теле об-

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

При генерации ИС их обработчики просматриваются в порядке их распо-

ложения в программе. Поэтому обработчик третьего типа следует помещать только после всех остальных. Также следует учитывать, что если обработчик ИС родительского класса будет стоять перед обработчиком ИС дочернего клас- са, то последний в этом случае не получит управления. Если исключения в за- щищаемом блоке не возникло, то все обработчики пропускаются.

В любом случае, произошло исключение или нет, управление передается

в блок завершения finally (если он существует), а затем первому оператору, находящемуся непосредственно за оператором try. В завершающем блоке обычно записываются операторы, которые необходимо выполнить независимо от того возникло исключение или нет. Обычно в этот блок помещают операто- ры, освобождающие ресурсы, выделяемые ОС программе, поэтому он еще ино- гда называется блоком защиты ресурсов.

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

чтобы оно было обработано на верхнем уровне. Генерация исключения выпол- няется при помощи оператора throw, который имеет следующий синтаксис:

throw[выражение]

Конструкция без параметра применяется только внутри блока catch для повторной генерации исключения. Тип выражения, стоящего после throw, оп- ределяет тип исключения, например:

throw new DivideByZeroException();

Здесь после оператора throw записано выражение, создающее объект

стандартного класса «ошибка деления на 0» с помощью оператора new.

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

При генерации исключения выполнение текущего блока прекращается и происходит поиск соответствующего обработчика с передачей ему управления. Обработчик считается найденным, если тип объекта, указанного после throw, либо тот же, что задан в параметре catch, либо является производным от не- го.

7.3. Программа работы

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

в ней исключительных ситуаций (деления на ноль, ввода чисел вместо цифр,

отсутствия динамически подключаемой библиотеки и т.д.).

Лабораторная работа № 8 (дополнительная)

Статьи к прочтению:

01. Что такое функция в математике


Похожие статьи: