Обработка ошибок и исключения — различия между версиями
Sergej (обсуждение | вклад) |
Sergej (обсуждение | вклад) (→Как обрабатывать?) |
||
Строка 26: | Строка 26: | ||
== Как обрабатывать? == | == Как обрабатывать? == | ||
Обрабатывать ошибку лучше там, где она возникла. Если в данном фрагменте кода нет возможности принять решение, что делать с исключением, его нужно бросать дальше, пока не найдется нужный обработчик, либо поток выполнения программы не вылетит совсем. | Обрабатывать ошибку лучше там, где она возникла. Если в данном фрагменте кода нет возможности принять решение, что делать с исключением, его нужно бросать дальше, пока не найдется нужный обработчик, либо поток выполнения программы не вылетит совсем. | ||
+ | |||
+ | class intException extends Exception { | ||
+ | intException(String message){ | ||
+ | super(message); | ||
+ | } | ||
+ | } | ||
+ | int division (int a) throws intExceprion{ | ||
+ | if (a == 0) throw new intException("Division by zero") | ||
+ | else return this / a; | ||
+ | } | ||
+ | try { | ||
+ | int c = a.division(b); | ||
+ | // Безопасное использование результата. | ||
+ | } catch (intException e) { | ||
+ | // Обработка ошибки | ||
+ | } |
Версия 21:13, 17 июня 2013
Определение: |
Исключениями или исключительными ситуациями (состояниями) называются ошибки, возникшие в программе во время её работы. |
Содержание
Введение
В языке
исключения и ошибки являются объектами. Когда метод вызывает (бросает - throws) исключительную ситуацию, он на самом деле работает с объектом. Но такое происходит не с любыми объектами, а только с теми, которые наследуются от, и их наследников еще называют , а всех остальных наследников класса обязывает пользователя обработать ее (использую конструкцию .) или же отдать на откуп обрамляющим методам, в таком случае к декларации метода, который бросает проверяемое исключение, дописывают конструкцию , например
public Date parse(String source) throws ParseException { ... }
Так когда же нужно бросать ошибки?
На этот вопрос можно ответить просто: если в методе возможна ситуация, которую метод не в состоянии обработать самостоятельно, он должен “бросать” ошибку. Но ни в коем случае нельзя использовать исключительные ситуации для управления ходом выполнения программы. Чаще всего контракта метода. Нарушение контракта со стороны создателя метода - это, например, что-нибудь на подобии . Пользователь метода может нарушить контракт, например, таким способом: на вход подать строку с буквами и по заслугам получить
бросаются при нарушенииА что собственно бросать?
Выбор не то чтобы сильно велик, но и не однозначен:
, В подавляющем большинстве случаев вам не понадобится. Это в основном критические ошибки (например, ), с которыми пусть работает JVM. , как было написано выше, заставляет программиста-пользователя написать код для ее обработки или же описать метод как “вызывающий исключительную ситуацию”. С можно поступить по-разному. В случае с такими ошибками, пользователь сам решает, будет он обрабатывать эту ошибку, или же нет (компилятор не заставляет это делать). Можно написать следующее простое правило: если некоторый набор входящих в метод данных может привести к нарушению контракта, и вы считаете, что программисту-пользователю важно разобраться с этим (и что он сможет это сделать), описывайте метод с конструкцией , иначе бросайтеКак обрабатывать?
Обрабатывать ошибку лучше там, где она возникла. Если в данном фрагменте кода нет возможности принять решение, что делать с исключением, его нужно бросать дальше, пока не найдется нужный обработчик, либо поток выполнения программы не вылетит совсем.
class intException extends Exception { intException(String message){ super(message); } } int division (int a) throws intExceprion{ if (a == 0) throw new intException("Division by zero") else return this / a; } try { int c = a.division(b); // Безопасное использование результата. } catch (intException e) { // Обработка ошибки }