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

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

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

Author24 — интернет-сервис помощи студентам
Когда, по вашему, лучше использовать исключения?
0
Лучшие ответы (1)
01.12.2015, 11:03
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 2
Knjagskij, в эту тему загляните. Там это же обсуждается.
1
183 / 181 / 66
Регистрация: 15.02.2015
Сообщений: 515
01.12.2015, 11:24 3
Ловить исключения или бросать?
Ловить стоит везде где они могут быть брошены. Какие исключения бросают те или иные функции должно быть задокументировано. Необработанное исключение - падение программы.
Бросание исключений это как сообщить другому программисту, использующему ваш код (библиотеку, например), об ошибке, как поступать с этой ошибкой решать ему, ваша задача, как можно более подробно описать её (либо задокументировать, либо передать всю нужную информацию в сообщении этого исключения). Бросать исключения в коде уже самого приложения, нет смысла, вам же его и ловить придётся.
1
2549 / 1208 / 358
Регистрация: 30.11.2013
Сообщений: 3,826
01.12.2015, 11:29 4
Цитата Сообщение от Operok Посмотреть сообщение
Бросать исключения в коде уже самого приложения, нет смысла
затрите пока никто не видел, а то портит пост
1
183 / 181 / 66
Регистрация: 15.02.2015
Сообщений: 515
01.12.2015, 11:57 5

Не по теме:

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


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

Решение

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

Почему еще это неудобно — конструктор вообще ничего не возвращает.
0
Эксперт С++
5057 / 3117 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 16:06 9
Knjagskij, ну, навскидку: 1) придётся на всех уровнях вложенности вызовов проверять коды ошибок и в случае неудачи пробрасывать код наверх, в место, где нужно обработать ошибку; 2) код ошибки не несёт дополнительной информации. Не открылся файл? Отлично. А какой файл? Конфиг? Или лог? Или какой-нибудь временный файл? Не будете же вы на эти три однородных ошибки 3 кода заводить.
0
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
01.12.2015, 16:08 10
Цитата Сообщение от silent_1991 Посмотреть сообщение
Не открылся файл? Отлично. А какой файл?
Тот, который только что пытались открыть)
0
183 / 181 / 66
Регистрация: 15.02.2015
Сообщений: 515
01.12.2015, 16:08 11
Цитата Сообщение от Knjagskij Посмотреть сообщение
А просто передавать некое число на выходе функции, которое в себе несет код ошибки чем не удобно?
Такой подход используют многие библиотеки. Без такого подхода никак в программировании COM и динамических библиотек (HRESULT), так как передать исключение в таких случаях не представляется возможным.
0
Эксперт С++
5057 / 3117 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 16:13 12
Цитата Сообщение от 0x10 Посмотреть сообщение
Тот, который только что пытались открыть)
Как мы узнаем, какой файл мы пытались открыть, если между местом возникновения ошибки и местом её обработки лежит 5 фреймов стека?)) Потому и написал, что обычно extra-data полезнее, чем сам тип ошибки.
0
-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
01.12.2015, 17:17  [ТС] 13
Мы можем структуру на выходе выдавать.
Цитата Сообщение от silent_1991 Посмотреть сообщение
Knjagskij, ну, навскидку: 1) придётся на всех уровнях вложенности вызовов проверять коды ошибок и в случае неудачи пробрасывать код наверх, в место, где нужно обработать ошибку; 2) код ошибки не несёт дополнительной информации. Не открылся файл? Отлично. А какой файл? Конфиг? Или лог? Или какой-нибудь временный файл? Не будете же вы на эти три однородных ошибки 3 кода заводить.
А как нам поможет исключение в этом случае, там же тоже названию сопоставляется обработчик.
Не разобрался, чем пара (throw, catch) отличается от (return, swich(if))?
0
Эксперт С++
5057 / 3117 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 17:21 14
Цитата Сообщение от Knjagskij Посмотреть сообщение
А как нам поможет исключение в этом случае
В каком из двух?)
В первом случае, нам ничего вручную пробрасывать не придётся, исключение поймается там, где будет соответствующий обработчик, хоть в функции main.
Во втором случае, объект исключения может нести дополнительную информацию, в приведённом случае, например, имя файла, который не удалось открыть, и причину, по которой это не удалось сделать (эту причину должна каким-либо образом вернуть функция открытия файла, это может быть код ошибки или, например, другой объект-исключение).
0
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
01.12.2015, 17:22 15
Цитата Сообщение от Knjagskij Посмотреть сообщение
Мы можем структуру на выходе выдавать.
Можно. Еще через пару итераций придешь к мысли, что можно возвращать сумму типов: variant<Result, Error>.
Цитата Сообщение от Knjagskij Посмотреть сообщение
А как нам поможет исключение в этом случае, там же тоже названию сопоставляется обработчик.
1. Кидают, как правило, осмысленные структуры с различимыми типами и информацией об ошибке.
2. Во время генерации исключения происходит раскрутка стека, что позволяет выбрать на каком уровне разумно обработать исключение, а не вручную пробрасывать код ошибки/структуру через все уровни.
3. Исключения помогают разделить код бизнес-логики и код обработки ошибок. В блоке try — логика, в блоках catch — обработка исключений. В случае кодов возврата нужно после каждого вызова писать код проверок.
1
-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
01.12.2015, 17:25  [ТС] 16
А если у нас два потока и один бросает исключение, то мы можем поймать его в другом?
0
Эксперт С++
5057 / 3117 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 17:26 17
Цитата Сообщение от 0x10 Посмотреть сообщение
Еще через пару итераций придешь к мысли, что можно возвращать сумму типов: variant<Result, Error>.
И, в общем-то, будет не далёк от истины) Тоже вполне себе подход к обработке ошибок, и много где используется по умолчанию.
0
-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
01.12.2015, 17:26  [ТС] 18
Честно говоря, все-равно до конца не понял, можете привести какой-нибудь пример, где исключениями пользоваться проще, чем if-ми?
0
Эксперт С++
5057 / 3117 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
01.12.2015, 17:43 19
Цитата Сообщение от 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  [ТС] 20
Отдельное спасибо, за
C++
1
code = openfile("/home/Knjagskij/file1.txt");
)))
А мы обязательно должны передавать в исключении объект? И число 10 - это просто параметр для примера, или в нем есть какой-то смысл?
C++
1
throw OpenFileException(name, 10);
Кстати, в ООП, как я понял, я является признаком хорошего тона возвращать значения атрибутов через методы? Или не обязательно, ведь, одно дело, если мы присваиваем им значения и их нужно проверять, а другое, если мы ничем не рискуем (при присвоении значения чему-либо из атрибута этого класса)
0
02.12.2015, 16:10
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.12.2015, 16:10
Помогаю со студенческими работами здесь

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

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

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

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

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


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

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

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Опции темы

Новые блоги и статьи
Отключение отслеживания файла, занесенного в .gitignore в Git
hw_wired 10.02.2025
Git помогает следить за изменениями в проекте, но иногда требуется исключить определенные файлы из системы контроля версий. Это могут быть конфигурационные файлы с локальными настройками, временные. . .
Что такое use strict в JavaScript
hw_wired 10.02.2025
Директива use strict - способ перевода JavaScript-кода в строгий режим работы, который делает язык более безопасным и предсказуемым. Она появилась в ECMAScript 5 как ответ на многочисленные проблемы,. . .
Как в jQuery проверить, что элемент скрыт
hw_wired 10.02.2025
jQuery предоставляет несколько эффективных способов определить, скрыт элемент или отображается на странице. Самый простой метод использует специальные селекторы :hidden и :visible. Селектор :hidden. . .
Как проверить (check out) ветку Git в удаленном репозитории
hw_wired 10.02.2025
Проверка удаленной ветки в Git требует понимания нескольких базовых концепций и точного выполнения определенной последовательности действий. Для начала необходимо получить актуальную информацию о. . .
chucknorris в HTML и другие обозначения цветов
hw_wired 10.02.2025
HTML, как основной язык разметки веб-страниц, прошел длинный путь развития в плане работы с цветами. На заре развития веб-технологий разработчики могли использовать только базовый набор из 16. . .
Стек и куча: отличия и назначение
hw_wired 10.02.2025
Управление памятью - ключевой элемент работы любой программы. В современных языках программирования память делится на две основные области: стек и кучу. Каждая из них обладает уникальными. . .
Комментарии в JSON
hw_wired 10.02.2025
JSON - текстовый формат обмена данными, построенный на основе синтаксиса JavaScript. Этот формат отличается простотой, читаемостью и широкой поддержкой во всех современных языках программирования. . . .
Перезаписываем локальные файлы с помощью git pull
hw_wired 10.02.2025
Git pull - незаменимая команда для синхронизации локального репозитория с удаленным. При работе над проектом в команде разработчиков часто возникает необходимость получить актуальные изменения,. . .
Оператор --> в C++
hw_wired 10.02.2025
Оператор --> (называемый "spaceship operator" или оператор космического корабля) - важное нововведение в стандарте C++20, упрощающее реализацию операций сравнения в пользовательских типах данных. . . .
Отмена git add до коммита
hw_wired 10.02.2025
Git предлагает несколько методов для отмены индексации файлов перед созданием коммита. Разработчики часто сталкиваются с ситуацией, когда нужно убрать файлы из индекса, не теряя внесенные изменения в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru