Объектно-ориентированное программирование на Java. Платформа Java SE. Тимур Машнин
Чтение книги онлайн.

Читать онлайн книгу Объектно-ориентированное программирование на Java. Платформа Java SE - Тимур Машнин страница 23

СКАЧАТЬ их наследники, за исключением наследников Error-а и RuntimeException – проверяемые.

      Error и RuntimeException и все их наследники – не проверяемые компилятором исключения.

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

      И так как проверяемое исключение проверяется во время компиляции, возникнет ошибка компиляции, если проверяемое исключение не обработано блоком try-catch, или оно не объявлено в заголовке или сигнатуре метода с помощью ключевого слова throws.

      Так почему не все исключения являются проверяемыми?

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

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

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

      Эту проверку создатели языка оставили программисту на его усмотрение.

      Таким образом, исключение RuntimeException является не проверяемым и выбрасывается во время выполнения Java кода, и его дочерние исключения также являются не проверяемыми.

      Это исключение IndexOutOfBoundsException – выбрасывается, когда индекс некоторого элемента в структуре данных не попадает в диапазон имеющихся индексов.

      Исключение NullPointerException – выбрасывается, когда ссылка на объект, к которому вы обращаетесь, хранит null.

      Исключение ClassCastException – это ошибка приведения типов.

      И исключение ArithmeticException – выбрасывается, когда выполняются недопустимые арифметические операции, например, деление на ноль.

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

      И его дочерние исключения, также не проверяемые, ThreadDeath – вызывается при неожиданной остановке потока.

      Исключение StackOverflowError – ошибка переполнение стека. Часто возникает в рекурсивных функциях из-за неправильного условия выхода.

      И исключение OutOfMemoryError – ошибка переполнения памяти.

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

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

      Иначе, суперкласс будет перехватывать все исключения, имея большую область перехвата.

      Иными словами, Exception не должен находиться выше ArithmeticException и ArrayIndexOutOfBoundsException.

      И еще, операторы try могут быть вложенными.

      Если вложенный оператор try не имеет своего обработчика catch для определения исключения, то идёт поиск обработчика catch у внешнего блока try и т. д.

      Если СКАЧАТЬ