ݺߣ

ݺߣShare a Scribd company logo
Стажировка-2014.
Обработка исключительных
ситуаций, журналирование и логи
Занятие 2 (часть 2)
Стажировка-2014.
Исключительная ситуация –
любая нештатная ситуация, в
которой программа не может
продолжить работу
Исключительные ситуации
Стажировка-2014.
Причины:
1. внутренние – ошибка в
программе
2. внешние – неверные входные
данные, проблемы в
конфигурации системы
Исключительные ситуации
Стажировка-2014.
Надежность программы –
устойчивость к возникновению
исключительных ситуаций
Исключительные ситуации
Стажировка-2014.
Что делать:
1. предотвращать – для
внутренних, конфигурационных
2. обрабатывать – для неверных
входных данных, недоступности
ресурсов
Исключительные ситуации
Стажировка-2014.
Защитное программирование –
стиль, при котором во всех
функциях (методах) обязательно
проверяется предусловие и при
невыполнении генерируется
исключительная ситуация
Исключительные ситуации
Стажировка-2014.
Защита от внутренних
ошибок:
1. утверждения (assert)
2. модульные тесты
Исключительные ситуации
Стажировка-2014.
Защита от неверных данных:
1. проверка предусловия –
только если просто
2. в остальных случаях –
отлавливание исключений
Исключительные ситуации
Стажировка-2014.
Функция (метод) может:
1. вернуть специальное значение
(-1, NULL, пустой объект, код
ошибки и т.д.)
2. выбросить исключение (если
язык поддерживает)
Исключительные ситуации
Стажировка-2014.
Функция (метод) не должна:
1. изменять глобальные объекты
программы
2. выводить информацию об
ошибке в консоль или внешний
файл
Исключительные ситуации
Стажировка-2014.
Хорошее поведение функции
(метода) в Java:
1. возвращать пустые объекты,
NULL
2. выбрасывать исключения
Исключительные ситуации
Стажировка-2014.
Важно:
список выбрасываемых
исключений – часть контракта
функции (метода)
Исключительные ситуации
Стажировка-2014.
Плохой стиль:
выбрасывать из функции
(метода) все возникшие в ней
исключения
Исключительные ситуации
Стажировка-2014.
В чем проблемы:
1. вызывающий код должен
подключать лишние библиотеки
2. слишком большой список
исключений
Исключительные ситуации
Стажировка-2014.
В чем проблемы:
3. раскрываются детали
реализации
4. затрудняется использование
интерфейсов
Исключительные ситуации
Стажировка-2014.
Хороший стиль:
создать свои исключения по
типам ситуаций и использовать
их
Исключительные ситуации
Стажировка-2014.
Логгирование –
фиксация только ошибочных
ситуаций и важных этапов работы
программы с целью поиска
внутренних и конфигурационных
ошибок
Журналирование и логи
Стажировка-2014.
Логгирование в Java –
библиотека log4j и надстройки
над ней, вывод в консоль или
файл
Журналирование и логи
Стажировка-2014.
Уровни логгирования в Java:
Fatal – фатальный сбой, нельзя
продолжать работу
Error – ошибка, можно
продолжать работу
Журналирование и логи
Стажировка-2014.
Уровни логгирования в Java:
Warning – потенциальная ошибка
Info – важный шаг, информация
Debug – отладочный вывод
Журналирование и логи
Стажировка-2014.
Принято логгировать:
1. пойманное исключение –
Error, Fatal
2. проблемы конфигурации –
Warning, Error, Fatal
Журналирование и логи
Стажировка-2014.
Принято логгировать:
3. начало и завершение важных
функций – особенно соединения с
внешними системами – с
сохранением отправленных и
принятых данных - Info
Журналирование и логи
Стажировка-2014.
Принято логгировать:
4. все подряд с уровнем Debug
Журналирование и логи
Стажировка-2014.
Помните:
грамотно организованное
логгирование сохранит вашу
карму от лучей смерти
команды поддержки
Журналирование и логи
Стажировка-2014.
Журналирование –
фиксация всех действий с целью
восстановления данных после
сбоя и возможности отката к
предыдущему состоянию
Журналирование и логи
Стажировка-2014.
Когда нужно журналирование:
1. финансовые системы
2. системы, от которых зависит
жизнь и здоровье
3. документооборот
4. любые базы данных
Журналирование и логи

More Related Content

Стажировка-2014, занятие 2 (часть 2). Исключения и логи