Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Проектирование библиотеки, как правильно 
V
    Опции темы
asmdzen
Дата 17.4.2012, 19:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата



**


Профиль
Группа: Участник
Сообщений: 345
Регистрация: 28.11.2010

Репутация: нет
Всего: 5



Пишу библиотеку - оболочку над dll файлом который работает с некоторым девайсом. Проблема заключается в том что я не знаю что именно нужно делать при критической ошибке и что при не критической.
Например в dll не содержатся все функции, т.е. присутствуют только самые нужные, при обнаружении таких ошибок я писал в лог, что сейчас делать не знаю.
При вызове метода, ему передается список значений в vector'е, некоторые значения недопустимы, как сказать пользователю?
При критических ошибках (dll файл отсутсвует) какие именно исключения выкидывать чтоб передать текст?
PM MAIL   Вверх
EvilsInterrupt
Дата 18.4.2012, 15:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Executables research
***


Профиль
Группа: Завсегдатай
Сообщений: 1019
Регистрация: 14.7.2007
Где: Железнодорожный, МО, Россия

Репутация: 2
Всего: 9



Не совсем понятно критичность относительно чего?
Я всегда делю критичность на:
* Критичность для стабильной работы системы в целом, ибо могут упасть другие проги
* Критичность по выполнению бизнес-задачи, к примеру при программе решающей квадр. уровнение дискриминант равен нулю, дальше решать нет смысла!
* Критичность по времени выполнения, пользователь живет не вечно и хочет знать насколько быстро его задача будет завершена.

PM MAIL WWW ICQ Jabber   Вверх
asmdzen
Дата 18.4.2012, 15:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата



**


Профиль
Группа: Участник
Сообщений: 345
Регистрация: 28.11.2010

Репутация: нет
Всего: 5



EvilsInterrupt, имелось ввиду критичность по отношению дальнейшей стабильной работы программы: нет нужного файла - программа не будет работать (критично, можно выбросить исключение), какой-то параметр из файла конфигурации неправильный - подставляем значение по умолчанию и идем дальше (нужно записать в лог, как это сделать если библиотека не знает о нем?)
PM MAIL   Вверх
KaZepKa
Дата 18.4.2012, 16:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 37
Регистрация: 29.10.2011

Репутация: нет
Всего: нет



Цитата(asmdzen @  18.4.2012,  16:50 Найти цитируемый пост)
(нужно записать в лог, как это сделать если библиотека не знает о нем?) 

Реализовать это в ней?
PM MAIL   Вверх
asmdzen
Дата 18.4.2012, 17:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата



**


Профиль
Группа: Участник
Сообщений: 345
Регистрация: 28.11.2010

Репутация: нет
Всего: 5



Цитата(KaZepKa @  18.4.2012,  16:34 Найти цитируемый пост)
Реализовать это в ней? 

наверное сделаю что-то типа string GetWarnings(); и пусть пользователь делает с ними что хочет.
В исключениях тоже добавлю поле с текстом ошибки.
PM MAIL   Вверх
EvilsInterrupt
Дата 18.4.2012, 17:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Executables research
***


Профиль
Группа: Завсегдатай
Сообщений: 1019
Регистрация: 14.7.2007
Где: Железнодорожный, МО, Россия

Репутация: 2
Всего: 9



asmdzen
Лично я для себя принял решение такое:
Если в случае разработки библиотечного кода выполнение бизнес-задачи библиотекой не возможно, то пишу log.debug_message() это отладочный лог предназначенный для разработчика и кидаю исключение. Выбрасывание исключения не дает проигнорировать проблему тому программисту кто использует библиотеку. Все таки надо отталкиваться от факта, что библиотека видит проблему, но не знает, что делать. А вот клиентский код не обязан определять траблы, но он лучше осведомлен о причинах.
О том что считать критичным, что нет, очень неплохо аргументировал Страуструп в своей последней книге.
PM MAIL WWW ICQ Jabber   Вверх
xvr
Дата 19.4.2012, 15:39 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 7046
Регистрация: 28.8.2007
Где: Дублин, Ирландия

Репутация: 60
Всего: 223



Можно сделать callback'и в самой библиотеке, которые она будет вызывать при критических и не критических ошибках. По умолчанию они будут реализованны в самой библиотеку и будут писать в лог файл, но пользователь библиотеки может подставить свои callback'и

PM MAIL   Вверх
EvilsInterrupt
Дата 20.4.2012, 15:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Executables research
***


Профиль
Группа: Завсегдатай
Сообщений: 1019
Регистрация: 14.7.2007
Где: Железнодорожный, МО, Россия

Репутация: 2
Всего: 9



Цитата(xvr @  19.4.2012,  16:39 Найти цитируемый пост)
Можно сделать callback'и в самой библиотеке, которые она будет вызывать при критических и не критических ошибках. По умолчанию они будут реализованны в самой библиотеку и будут писать в лог файл, но пользователь библиотеки может подставить свои callback'и

Я бы не стал такое делать в юзермодном, пусть даже системном коде. Такое решение больше подходит для  уровня ядра.
Дело в том что клиент, т.е. программист пишущий код использующий библиотеку может не установить колбаков и как вывод при критичной проблеме приложение не отреагирует должным образом.
В случае бросания исключения это вынудит клиент посмотреть проблему и написать код обрабатывающий ее!

Но есть нюансы ;)

Автору темы рекомендую почитать обработка исключений

Это сообщение отредактировал(а) EvilsInterrupt - 20.4.2012, 15:07
PM MAIL WWW ICQ Jabber   Вверх
xvr
Дата 20.4.2012, 17:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 7046
Регистрация: 28.8.2007
Где: Дублин, Ирландия

Репутация: 60
Всего: 223



Цитата(EvilsInterrupt @  20.4.2012,  15:07 Найти цитируемый пост)
Дело в том что клиент, т.е. программист пишущий код использующий библиотеку может не установить колбаков и как вывод при критичной проблеме приложение не отреагирует должным образом.

Обработчик по умолчанию должен терминировать приложение (с записью в лог). 'Не отреагировать' на это будет довольно затруднительно  smile 
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0720 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.