Форум Flasher.ru
Ближайшие курсы в Школе RealTime
Список интенсивных курсов: [см.]  
  
Специальные предложения: [см.]  
  
 
Блоги Правила Справка Пользователи Календарь Сообщения за день
 

Вернуться   Форум Flasher.ru > Flash > ActionScript 3.0

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему Ответ
Старый 13.11.2011, 20:52
Inet_PC вне форума Посмотреть профиль Отправить личное сообщение для Inet_PC Посетить домашнюю страницу Inet_PC Найти все сообщения от Inet_PC
  № 11  
Ответить с цитированием
Inet_PC
 
Аватар для Inet_PC

Регистрация: Feb 2009
Адрес: Гы...поди, найди!
Сообщений: 853
Записей в блоге: 1
Цитата:
try|catch медленней чем if.
Вы правы только отчасти, вот в этой теме Psycho Tiger доказал мне, что выгодней использовать try/catch нежели if, ибо быстрее, и if выигрывает только когда ошибка. А ошибка это исключительная ситуации, в готовом приложении их количество должно быть гораздо меньше, чем нормальных.
1. try/catch приходится использовать при использовании нативных методов, к. генерируют исключения.
2. При вызове методов из других библиотек, ибо их автор возможно что-то не учел, или сам генерирует исключения и тут без try/catch так же не обойтись.
В общем случае я тоже за то, чтобы обходится if-ами.
__________________
http://www.chessmax.ru

Старый 13.11.2011, 21:23
GBee вне форума Посмотреть профиль Отправить личное сообщение для GBee Найти все сообщения от GBee
  № 12  
Ответить с цитированием
GBee
 
Аватар для GBee

Регистрация: Jan 2009
Сообщений: 3,067
Записей в блоге: 3
Отправить сообщение для GBee с помощью Skype™
Цитата:
Вы правы только отчасти, вот в этой теме Psycho Tiger доказал мне, что выгодней использовать try/catch нежели if, ибо быстрее, и if выигрывает только когда ошибка. А ошибка это исключительная ситуации, в готовом приложении их количество должно быть гораздо меньше, чем нормальных.
Если честно не очень понял, там по теме в if дергался неслабенький метод с блекджеком и циклами. Впрочем в с Тигрой там к этому и пришли, как я понял.

Цитата:
В общем случае я тоже за то, чтобы обходится if-ами.
+1 и правильная архитектура, а не как в той теме :о)
__________________
Чтобы доказать, что вы не робот, причините вред другому человеку.

Старый 13.11.2011, 21:31
Psycho Tiger вне форума Посмотреть профиль Отправить личное сообщение для Psycho Tiger Найти все сообщения от Psycho Tiger
  № 13  
Ответить с цитированием
Psycho Tiger
 
Аватар для Psycho Tiger

блогер
Регистрация: Jun 2005
Адрес: Toronto
Сообщений: 6,599
Записей в блоге: 17
Вот при обращении к свойству, которое null генерируется RTE (я про value.key, когда value = null).
Вы представляете, если бы генерировалось событие, например? Вот в таких вещах оно и надо. В ядре. RTE не должны выбрасываться в продакшн-версии, зато если оно вывалилось при девелопе - можно сразу понять, что было сделано не так. Как уже подметили, IDE сваливается в дебаг.

Старый 13.11.2011, 22:35
expl вне форума Посмотреть профиль Отправить личное сообщение для expl Найти все сообщения от expl
  № 14  
Ответить с цитированием
expl

блогер
Регистрация: Feb 2006
Сообщений: 1,474
Записей в блоге: 3
Про то зачем нужны ислючения и когда ими надо пользоваться очень хорошо написано в древней, христоматийной крижке Стива Макконнела "Совершенный код"
http://www.ozon.ru/context/detail/id/3159814/
Там именно про стратегии использования (включаяя assert'ы) - про обработку ошибок в месте их появления, не допуская их в глубь программы, где уже не разберешься кто виноват.
Про эшелоны борьбы с ошибками.

Основные принципы по киданию исключений:
- Если метод сам не в состоянии правильно отреагировать на кривые данные - ну не знает он о другой части системы - вот с помощью исключения он и передает обработку ошибки выше
- Если метод более высокого уровня тоже не может ничего сделать (например показать окошко "Попробуйте еще" или откатить правки, или перезагрузить данные, или тупо в лог вывести, или вообще показать окно "В конфиге неправильный адрес - правьте и перезагружайтесь")
то он должен передавать более высокому в иерархии методу более детальное исключение, не просто "null-exception", а описание чего пытались сделать и почему не получилось - более высокий метод же не должен в низком уровне иерархии для этого копаться.
И т.д. и т.п.

Цитата:
Если запись не добавилась, то в что лучше делать на стороне клиента - выбрасывать исключение или просто прекращать работу метода (return) и выводить сообщение юзеру об ошибке(Alert.Show)?
Конечный пользователь в идеале не должен видеть исключения _никогда_. Исключение кидают не чтобы появилось забавное окошко со стеком вызвовов, а чтобы подсистема более высокого уровня отреагировала на ситуацию.
Можно, конечно и без исключений, но тогда из функции придется как-то получать информацию об ошибке, т.е. код усложниться просто.

Зачем это окошко пользователю? Тем более если флешплеер не дебажный - он вообще об ошибке не узнает.

Пользователь должен видеть, то, что ему понятно. На худой конец, чтобы принимать баг-репорты можно сделать флешовое окошко, в котором будет кнопка "Send to support", по которой вам на мыло придет этот самый стек вызовов.


Последний раз редактировалось expl; 14.11.2011 в 00:18.
Старый 14.11.2011, 07:43
kackbip вне форума Посмотреть профиль Отправить личное сообщение для kackbip Найти все сообщения от kackbip
  № 15  
Ответить с цитированием
kackbip
 
Аватар для kackbip

Регистрация: Sep 2007
Адрес: Tomsk
Сообщений: 943
Отправить сообщение для kackbip с помощью ICQ Отправить сообщение для kackbip с помощью Skype™
Цитата:
RTE не должны выбрасываться в продакшн-версии
Если они перехватываются - почему бы и нет.

Старый 14.11.2011, 08:37
goodguy вне форума Посмотреть профиль Найти все сообщения от goodguy
  № 16  
Ответить с цитированием
goodguy
Banned
[+1 05.11.11]
[+1 09.08.11]

Регистрация: Jan 2010
Адрес: РФ. Кемеровская область
Сообщений: 3,243
Не вижу смысла самому кидать ошибку, и самому же ее перехватывать )

Старый 14.11.2011, 10:35
carrotoff вне форума Посмотреть профиль Отправить личное сообщение для carrotoff Найти все сообщения от carrotoff
  № 17  
Ответить с цитированием
carrotoff
 
Аватар для carrotoff

Регистрация: May 2010
Сообщений: 543
Цитата:
Не вижу смысла самому кидать ошибку, и самому же ее перехватывать )
Смысл будет заметнее, если занимаешься разработкой не один. Но если всё-таки один, то в принципе согласен
__________________
Вы грабите бедных людей. Парень со свирелью накажет вас. Хонгильдон (с)

Старый 14.11.2011, 11:29
kackbip вне форума Посмотреть профиль Отправить личное сообщение для kackbip Найти все сообщения от kackbip
  № 18  
Ответить с цитированием
kackbip
 
Аватар для kackbip

Регистрация: Sep 2007
Адрес: Tomsk
Сообщений: 943
Отправить сообщение для kackbip с помощью ICQ Отправить сообщение для kackbip с помощью Skype™
Любая большая система представляет из себя набор взаимодействующих модулей. Каждый из этих модулей должен быть черным ящиком, который в том числе может и дать сбой при некорректном использовании, некорректных входных данным и т.д. В данном случае исключение вполне логично. И его естественно нужно перехватить в вышестоящем модуле.
Цитата:
Не вижу смысла самому кидать ошибку, и самому же ее перехватывать )
Угу... а так же нет смысла генерировать события и самому их обрабатывать?

Старый 14.11.2011, 11:39
carrotoff вне форума Посмотреть профиль Отправить личное сообщение для carrotoff Найти все сообщения от carrotoff
  № 19  
Ответить с цитированием
carrotoff
 
Аватар для carrotoff

Регистрация: May 2010
Сообщений: 543
Цитата:
Угу... а так же нет смысла генерировать события и самому их обрабатывать?
Не, ну это утрирование, конечно. Но в целом абсолютно согласен. В случае крупной системы взаимодействующих модулей вероятность того, что один из ее компонентов поведет себя нештатно присутствует. И в этом случае исключения как нельзя кстати
__________________
Вы грабите бедных людей. Парень со свирелью накажет вас. Хонгильдон (с)

Старый 14.11.2011, 11:48
kackbip вне форума Посмотреть профиль Отправить личное сообщение для kackbip Найти все сообщения от kackbip
  № 20  
Ответить с цитированием
kackbip
 
Аватар для kackbip

Регистрация: Sep 2007
Адрес: Tomsk
Сообщений: 943
Отправить сообщение для kackbip с помощью ICQ Отправить сообщение для kackbip с помощью Skype™
Цитата:
Не, ну это утрирование
Я соглашусь если ты мне покажешь принципиальную разницу между исключением и событием ошибки.

Создать новую тему Ответ Часовой пояс GMT +4, время: 10:03.
Быстрый переход
  « Предыдущая тема | Следующая тема »  

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


 


Часовой пояс GMT +4, время: 10:03.


Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2026, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.