Console.WriteLine(

"Перед генерированием исключения.");

// Генерируем исключение, связанное с попаданием

// индексавнедиапазона,

for(int i=0; i < 10; i++) {

nums[i] = i;

Console.WriteLine("nums[{0}]: {1}", i, nums[i]);

}

Console.WriteLine("Этот текст не отображается.");

}

catch (IndexOutOfRangeException) {

// Перехватываем исключение.

Console.WriteLine("Индекс вне диапазона!");

}

Console.WriteLine("После catch-инструкции.");

}}

При выполнении этой программы получаем такие результаты:

Перед генерированием исключения.

nums[0]: 0

nums[1]: 1

nums[2]: 2

nums[3]: 3

Индекс вне диапазона!

После catch-инструкции.

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

usingSystem;

classExcDemo2 {

public static void Main() {

int[] numer = { 4, 8, 16, 32, 64, 128 };

int[] denom = { 2, 0, 4, 4, 0, 8 };

for(int i=0; i < numer.Length; i++){

try {

Console.WriteLine(numer[i] + " / " + denom[i] + " равно " +

numer[i]/denom[i]);

}

catch (DivideByZeroException) { // Перехватываем исключение.

Console.WriteLine("Делить на нуль нельзя!");

}}}}

 

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

4 / 2

равно 2

Делить на нуль нельзя!

16 / 4

равно 4

32 / 4

равно 8

Делить на нуль нельзя!

128 / 8 равно 16

 

С try-блоком можно связать не одно, а несколько catch-инструкций.

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

// Использование нескольких catch-инструкций.

usingSystem;

class ExcDemo3 {

public static void Main() {

// Здесь массив numer длинне массива denom.

int [] numer = { 4, 8, 16, 32, 64, 128, 256, 512 };

int[] denom = { 2, 0, 4, 4, 0 , 8 };

for(int i=0; i < numer.Length;i++){

try {

Console.WriteLine(numer[i] + " / " +denom[i] + " равно " +

numer[i]/denom[i]);

}

catch (DivideByZeroException) {// Перехватываем исключение

Console.WriteLine("Делитьнанульнельзя!");

}

catch (IndexOutOfRangeException) {

// Перехватываем исключение.

Console.WriteLine("Нет соответствующего элемента.")

}}}}

Эта программа генерирует следующие результаты:

4/2

равно 2

Делить на нуль нельзя!

16/4

равно 4

32/4

равно 8

Делить на нуль нельзя!

128/8 равно 16

Нет соответствующего элемента.

Нет соответствующего элемента.

 

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

 

7.4 Перехват всех исключений

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

//Использование catch-инструкции для “глобального перехвата".

using System;

class ExcDemo4 {

public static void Main() {

// Здесь массив numer длиннее массива denoiti.

int[] numer = { 4, 8, 16, 32, 64, 128, 256, 512 };

int[] denom = { 2 , 0, 4, 4, 0, 8 } ;

for(int i=0; i < numer.Length; i++){

try {

Console.WriteLine(numer[i] + " / " +

denom[i] + " равно " +

numer[i]/denom[i]);

}

catch {