![]() |
|
||||||||||
|
|||||
|
Цитата:
1. try/catch приходится использовать при использовании нативных методов, к. генерируют исключения. 2. При вызове методов из других библиотек, ибо их автор возможно что-то не учел, или сам генерирует исключения и тут без try/catch так же не обойтись. В общем случае я тоже за то, чтобы обходится if-ами.
__________________
http://www.chessmax.ru |
|
|||||
|
Цитата:
Цитата:
__________________
Чтобы доказать, что вы не робот, причините вред другому человеку. |
|
|||||
|
Вот при обращении к свойству, которое null генерируется RTE (я про value.key, когда value = null).
Вы представляете, если бы генерировалось событие, например? Вот в таких вещах оно и надо. В ядре. RTE не должны выбрасываться в продакшн-версии, зато если оно вывалилось при девелопе - можно сразу понять, что было сделано не так. Как уже подметили, IDE сваливается в дебаг.
__________________
Тут мужик танцует и поёт про флэш |
|
|||||
|
Про то зачем нужны ислючения и когда ими надо пользоваться очень хорошо написано в древней, христоматийной крижке Стива Макконнела "Совершенный код"
http://www.ozon.ru/context/detail/id/3159814/ Там именно про стратегии использования (включаяя assert'ы) - про обработку ошибок в месте их появления, не допуская их в глубь программы, где уже не разберешься кто виноват. Про эшелоны борьбы с ошибками. Основные принципы по киданию исключений: - Если метод сам не в состоянии правильно отреагировать на кривые данные - ну не знает он о другой части системы - вот с помощью исключения он и передает обработку ошибки выше - Если метод более высокого уровня тоже не может ничего сделать (например показать окошко "Попробуйте еще" или откатить правки, или перезагрузить данные, или тупо в лог вывести, или вообще показать окно "В конфиге неправильный адрес - правьте и перезагружайтесь") то он должен передавать более высокому в иерархии методу более детальное исключение, не просто "null-exception", а описание чего пытались сделать и почему не получилось - более высокий метод же не должен в низком уровне иерархии для этого копаться. И т.д. и т.п. Цитата:
Можно, конечно и без исключений, но тогда из функции придется как-то получать информацию об ошибке, т.е. код усложниться просто. Зачем это окошко пользователю? Тем более если флешплеер не дебажный - он вообще об ошибке не узнает. Пользователь должен видеть, то, что ему понятно. На худой конец, чтобы принимать баг-репорты можно сделать флешовое окошко, в котором будет кнопка "Send to support", по которой вам на мыло придет этот самый стек вызовов. Последний раз редактировалось expl; 14.11.2011 в 00:18. |
|
|||||
|
Цитата:
|
|
|||||
|
Banned
[+1 05.11.11]
[+1 09.08.11] Регистрация: Jan 2010
Адрес: РФ. Кемеровская область
Сообщений: 3,243
|
Не вижу смысла самому кидать ошибку, и самому же ее перехватывать )
|
|
|||||
|
Регистрация: May 2010
Сообщений: 543
|
Цитата:
__________________
Вы грабите бедных людей. Парень со свирелью накажет вас. Хонгильдон (с) |
|
|||||
|
Любая большая система представляет из себя набор взаимодействующих модулей. Каждый из этих модулей должен быть черным ящиком, который в том числе может и дать сбой при некорректном использовании, некорректных входных данным и т.д. В данном случае исключение вполне логично. И его естественно нужно перехватить в вышестоящем модуле.
Цитата:
![]() |
|
|||||
|
Регистрация: May 2010
Сообщений: 543
|
Цитата:
![]()
__________________
Вы грабите бедных людей. Парень со свирелью накажет вас. Хонгильдон (с) |
|
|||||
|
Цитата:
|
![]() |
![]() |
Часовой пояс GMT +4, время: 10:03. |
|
|
« Предыдущая тема | Следующая тема » |
|
|