-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776

Когда нужно использовать исключения

01.12.2015, 11:03. Показов 2026. Ответов 21
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Когда, по вашему, лучше использовать исключения?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.12.2015, 11:03
Ответы с готовыми решениями:

Когда нужно использовать &ссылки ,а когда *указатели?
Желательно с примерами

Объяснить (с примерами) для чего нужен RTTI, как и когда его можно и нужно использовать
доброго времени суток. вопрос такой как я понял RTTI это свойсвто языка С++ которое было добавлено позднее его релиза, что бы...

Когда стоит использовать класс, а когда лучше обойтись без них?
Когда стоит использовать класс, а когда лучше обойтись без них? Когда следует использовать несколько классов? Вот, например. Программа...

21
Эксперт PHP
 Аватар для Kerry_Jr
3106 / 2591 / 1219
Регистрация: 14.05.2014
Сообщений: 7,236
Записей в блоге: 1
01.12.2015, 11:07
Knjagskij, в эту тему загляните. Там это же обсуждается.
1
183 / 181 / 66
Регистрация: 15.02.2015
Сообщений: 515
01.12.2015, 11:24
Ловить исключения или бросать?
Ловить стоит везде где они могут быть брошены. Какие исключения бросают те или иные функции должно быть задокументировано. Необработанное исключение - падение программы.
Бросание исключений это как сообщить другому программисту, использующему ваш код (библиотеку, например), об ошибке, как поступать с этой ошибкой решать ему, ваша задача, как можно более подробно описать её (либо задокументировать, либо передать всю нужную информацию в сообщении этого исключения). Бросать исключения в коде уже самого приложения, нет смысла, вам же его и ловить придётся.
1
2549 / 1208 / 358
Регистрация: 30.11.2013
Сообщений: 3,826
01.12.2015, 11:29
Цитата Сообщение от Operok Посмотреть сообщение
Бросать исключения в коде уже самого приложения, нет смысла
затрите пока никто не видел, а то портит пост
1
183 / 181 / 66
Регистрация: 15.02.2015
Сообщений: 515
01.12.2015, 11:57

Не по теме:

Цитата Сообщение от rikimaru2013 Посмотреть сообщение
затрите
поздно :(


Я наверное не так выразился. Нет смысла кидать исключения в коде, который не будет использоваться в других приложениях. Например, обработка параметров функции main, даже если для этого написал небольшой класс, достаточно вывести сообщение пользователю. Т.е. я либо ловлю исключения и сообщаю при необходимости пользователю (текст в консоли или message box), либо при возникновении исключительной ситуации уже обрабатываю её (не бросая исключения), при необходимости сообщая что-нибудь пользователю.
0
Эксперт по математике/физикеЭксперт С++
 Аватар для Ilot
2223 / 1425 / 420
Регистрация: 16.05.2013
Сообщений: 3,642
Записей в блоге: 6
01.12.2015, 12:06
Лучший ответ Сообщение было отмечено SatanaXIII как решение

Решение

Цитата Сообщение от Knjagskij Посмотреть сообщение
Когда, по вашему, лучше использовать исключения?
Исключения используются там где затруднено сообщить о возникновении ошибки. Как то конструкторы, сложные методы и функции и т.д.
0
-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
01.12.2015, 16:01  [ТС]
А просто передавать некое число на выходе функции, которое в себе несет код ошибки чем не удобно?
0
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
01.12.2015, 16:05
Цитата Сообщение от Knjagskij Посмотреть сообщение
А просто передавать некое число на выходе функции, которое в себе несет код ошибки чем не удобно?
Такой подход предполагает, что где-то для каждого числа должна быть сопоставлена строка с человекопонятным описанием.
См похожее: errno, perror.
С той разницей, что errno — глобальная переменная.

Почему еще это неудобно — конструктор вообще ничего не возвращает.
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 16:06
Knjagskij, ну, навскидку: 1) придётся на всех уровнях вложенности вызовов проверять коды ошибок и в случае неудачи пробрасывать код наверх, в место, где нужно обработать ошибку; 2) код ошибки не несёт дополнительной информации. Не открылся файл? Отлично. А какой файл? Конфиг? Или лог? Или какой-нибудь временный файл? Не будете же вы на эти три однородных ошибки 3 кода заводить.
0
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
01.12.2015, 16:08
Цитата Сообщение от silent_1991 Посмотреть сообщение
Не открылся файл? Отлично. А какой файл?
Тот, который только что пытались открыть)
0
183 / 181 / 66
Регистрация: 15.02.2015
Сообщений: 515
01.12.2015, 16:08
Цитата Сообщение от Knjagskij Посмотреть сообщение
А просто передавать некое число на выходе функции, которое в себе несет код ошибки чем не удобно?
Такой подход используют многие библиотеки. Без такого подхода никак в программировании COM и динамических библиотек (HRESULT), так как передать исключение в таких случаях не представляется возможным.
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 16:13
Цитата Сообщение от 0x10 Посмотреть сообщение
Тот, который только что пытались открыть)
Как мы узнаем, какой файл мы пытались открыть, если между местом возникновения ошибки и местом её обработки лежит 5 фреймов стека?)) Потому и написал, что обычно extra-data полезнее, чем сам тип ошибки.
0
-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
01.12.2015, 17:17  [ТС]
Мы можем структуру на выходе выдавать.
Цитата Сообщение от silent_1991 Посмотреть сообщение
Knjagskij, ну, навскидку: 1) придётся на всех уровнях вложенности вызовов проверять коды ошибок и в случае неудачи пробрасывать код наверх, в место, где нужно обработать ошибку; 2) код ошибки не несёт дополнительной информации. Не открылся файл? Отлично. А какой файл? Конфиг? Или лог? Или какой-нибудь временный файл? Не будете же вы на эти три однородных ошибки 3 кода заводить.
А как нам поможет исключение в этом случае, там же тоже названию сопоставляется обработчик.
Не разобрался, чем пара (throw, catch) отличается от (return, swich(if))?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 17:21
Цитата Сообщение от Knjagskij Посмотреть сообщение
А как нам поможет исключение в этом случае
В каком из двух?)
В первом случае, нам ничего вручную пробрасывать не придётся, исключение поймается там, где будет соответствующий обработчик, хоть в функции main.
Во втором случае, объект исключения может нести дополнительную информацию, в приведённом случае, например, имя файла, который не удалось открыть, и причину, по которой это не удалось сделать (эту причину должна каким-либо образом вернуть функция открытия файла, это может быть код ошибки или, например, другой объект-исключение).
0
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
01.12.2015, 17:22
Цитата Сообщение от Knjagskij Посмотреть сообщение
Мы можем структуру на выходе выдавать.
Можно. Еще через пару итераций придешь к мысли, что можно возвращать сумму типов: variant<Result, Error>.
Цитата Сообщение от Knjagskij Посмотреть сообщение
А как нам поможет исключение в этом случае, там же тоже названию сопоставляется обработчик.
1. Кидают, как правило, осмысленные структуры с различимыми типами и информацией об ошибке.
2. Во время генерации исключения происходит раскрутка стека, что позволяет выбрать на каком уровне разумно обработать исключение, а не вручную пробрасывать код ошибки/структуру через все уровни.
3. Исключения помогают разделить код бизнес-логики и код обработки ошибок. В блоке try — логика, в блоках catch — обработка исключений. В случае кодов возврата нужно после каждого вызова писать код проверок.
1
-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
01.12.2015, 17:25  [ТС]
А если у нас два потока и один бросает исключение, то мы можем поймать его в другом?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 17:26
Цитата Сообщение от 0x10 Посмотреть сообщение
Еще через пару итераций придешь к мысли, что можно возвращать сумму типов: variant<Result, Error>.
И, в общем-то, будет не далёк от истины) Тоже вполне себе подход к обработке ошибок, и много где используется по умолчанию.
0
-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
01.12.2015, 17:26  [ТС]
Честно говоря, все-равно до конца не понял, можете привести какой-нибудь пример, где исключениями пользоваться проще, чем if-ми?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 17:43
Цитата Сообщение от Knjagskij Посмотреть сообщение
А если у нас два потока и один бросает исключение, то мы можем поймать его в другом?
Нет, исключения нужно обязательно поймать где-то в потоке, в котором оно возникло, если оно выйдет из точки входа потока, вызовется std::terminate.

Добавлено через 4 минуты
Сейчас накидаю вам пример.

Добавлено через 8 минут
Простенький пример.
С исключениями: http://ideone.com/1awEGD
Без исключений: http://ideone.com/ddJv4s
Тут всего один уровень вложенности (функция handlefiles вызывает проблемную функцию openfile). А представьте, если проблемных функций много, все могут вернуть разные ошибки, и много уровней вложенности, а нам надо ошибку обработать далеко от места её возникновения? Куча if'ов, возвраты кодов ошибок, которые функция по логике возвращать не должна (где-то в недрах не открылся файл, о котором пользователь и знать не должен, а ему из интерфейсной функции летит такой код ошибки).
2
-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
02.12.2015, 16:10  [ТС]
Отдельное спасибо, за
C++
1
code = openfile("/home/Knjagskij/file1.txt");
)))
А мы обязательно должны передавать в исключении объект? И число 10 - это просто параметр для примера, или в нем есть какой-то смысл?
C++
1
throw OpenFileException(name, 10);
Кстати, в ООП, как я понял, я является признаком хорошего тона возвращать значения атрибутов через методы? Или не обязательно, ведь, одно дело, если мы присваиваем им значения и их нужно проверять, а другое, если мы ничем не рискуем (при присвоении значения чему-либо из атрибута этого класса)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.12.2015, 16:10
Помогаю со студенческими работами здесь

Когда надо использовать списки инициализации, а когда можно заменить их констуктором по умолчанию?
1)Любезные,скажите когда надо исп. списки инициализации, а когда можно заменить констуктором по умолчанию? 2) правильно ли...

Когда использовать WinAPI, а когда функции языка?
Не совсем понимаю, когда нужно использовать WinAPI в приложении, а когда функционал самого ЯП (С/С++). Для той же работы с файлами...

Когда использовать указатели, а когда передачу по ссылке?
Когда использовать указатели, а когда передачу по ссылке?

Когда использовать указатели ,а когда ссылки?
Когда использовать указатели ,а когда ссылки?

Работает ли указатель на базовый класс исключения, когда попадает в блок catch
Работает ли указатель на базовый класс исключения, когда попадает в блок catch так же как обычно? То есть, если есть переопределенные...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru