-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
|
|
1 | |
Когда нужно использовать исключения01.12.2015, 11:03. Показов 1656. Ответов 21
Метки нет Все метки)
(
0
|
01.12.2015, 11:03 | |
01.12.2015, 11:03 | |
Ответы с готовыми решениями:
21
Когда нужно использовать &ссылки ,а когда *указатели? Объяснить (с примерами) для чего нужен RTTI, как и когда его можно и нужно использовать
|
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 |
1
|
183 / 181 / 66
Регистрация: 15.02.2015
Сообщений: 515
|
|
01.12.2015, 11:57 | 5 |
Я наверное не так выразился. Нет смысла кидать исключения в коде, который не будет использоваться в других приложениях. Например, обработка параметров функции main , даже если для этого написал небольшой класс, достаточно вывести сообщение пользователю. Т.е. я либо ловлю исключения и сообщаю при необходимости пользователю (текст в консоли или message box), либо при возникновении исключительной ситуации уже обрабатываю её (не бросая исключения), при необходимости сообщая что-нибудь пользователю.
0
|
![]() ![]() ![]() |
|
01.12.2015, 12:06 | 6 |
![]() Решение
Исключения используются там где затруднено сообщить о возникновении ошибки. Как то конструкторы, сложные методы и функции и т.д.
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 |
Такой подход предполагает, что где-то для каждого числа должна быть сопоставлена строка с человекопонятным описанием.
См похожее: 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 |
0
|
183 / 181 / 66
Регистрация: 15.02.2015
Сообщений: 515
|
|
01.12.2015, 16:08 | 11 |
Такой подход используют многие библиотеки. Без такого подхода никак в программировании COM и динамических библиотек (HRESULT), так как передать исключение в таких случаях не представляется возможным.
0
|
![]() 5057 / 3117 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
01.12.2015, 16:13 | 12 |
Как мы узнаем, какой файл мы пытались открыть, если между местом возникновения ошибки и местом её обработки лежит 5 фреймов стека?)) Потому и написал, что обычно extra-data полезнее, чем сам тип ошибки.
0
|
-2 / 8 / 2
Регистрация: 10.11.2008
Сообщений: 776
|
|
01.12.2015, 17:17 [ТС] | 13 |
Мы можем структуру на выходе выдавать.
А как нам поможет исключение в этом случае, там же тоже названию сопоставляется обработчик. Не разобрался, чем пара (throw, catch) отличается от (return, swich(if))?
0
|
![]() 5057 / 3117 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
|
|
01.12.2015, 17:21 | 14 |
В каком из двух?)
В первом случае, нам ничего вручную пробрасывать не придётся, исключение поймается там, где будет соответствующий обработчик, хоть в функции main. Во втором случае, объект исключения может нести дополнительную информацию, в приведённом случае, например, имя файла, который не удалось открыть, и причину, по которой это не удалось сделать (эту причину должна каким-либо образом вернуть функция открытия файла, это может быть код ошибки или, например, другой объект-исключение).
0
|
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
|
|
01.12.2015, 17:22 | 15 |
Можно. Еще через пару итераций придешь к мысли, что можно возвращать сумму типов: variant<Result, Error>.
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 |
И, в общем-то, будет не далёк от истины) Тоже вполне себе подход к обработке ошибок, и много где используется по умолчанию.
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 |
Нет, исключения нужно обязательно поймать где-то в потоке, в котором оно возникло, если оно выйдет из точки входа потока, вызовется 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 | ||||||||||
Отдельное спасибо, за
А мы обязательно должны передавать в исключении объект? И число 10 - это просто параметр для примера, или в нем есть какой-то смысл?
0
|
02.12.2015, 16:10 | |
02.12.2015, 16:10 | |
Помогаю со студенческими работами здесь
20
Когда надо использовать списки инициализации, а когда можно заменить их констуктором по умолчанию? Когда использовать WinAPI, а когда функции языка?
Когда использовать указатели ,а когда ссылки? Работает ли указатель на базовый класс исключения, когда попадает в блок catch Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
![]() |
Опции темы | |
|
Новые блоги и статьи
![]() |
||||
Отключение отслеживания файла, занесенного в .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 предлагает несколько методов для отмены индексации файлов перед созданием коммита. Разработчики часто сталкиваются с ситуацией, когда нужно убрать файлы из индекса, не теряя внесенные изменения в. . .
|