grig_p
grig_p19 августа 2019 г. 3:39

Exceptions Обработка исключений в программе

Здравствуйте!
Хотелось бы в своем приложении сделать цетрализованную обработку исключительных ситуаций для их логирования.
Переопределил метод notify():

static const int EC_MAINLOOP_ERROR = 1;
static const int EC_MAINLOOP_UNKNOWN_ERROR = 2;

bool MyAppApplication::notify(QObject *re, QEvent *ev)
{
    try
    {
        return QApplication::notify(re, ev);
    }
    catch(QString &e)
    {
        QString s = QString("Программа аварийно завершила свою работу с сообщением: %1. Источник %2").
                      arg(e).arg(re->objectName());
        qDebug() << s;
        log(s);  // Запись в лог
        QTimer::singleShot(0, this, [this]()
        {
            exit(EC_MAINLOOP_ERROR);
        });
    }
    catch(...)
    {
        QString s = QString("Программа аварийно завершила свою работу по неизвестной причине. Источник %1")
                    .arg(re->objectName());
        qDebug() << s;
        log(s);  // Запись в лог
        QTimer::singleShot(0, this, [this]()
        {
            exit(EC_MAINLOOP_UNKNOWN_ERROR);
        });
    }
    return false;
}

Далее,
если я вызываю исключение так: throw 1; - управление передается notify(), исключение обрабатывается, логируется и т.д.
если же я вызываю сбой, например так:
int v = 0;
v = 25 / v;
То сбой не доходит до notify(), появляется сообщение и программа закрывается.

Обрамлял исключение в свой блок try catch:

try
{
    int v = 0;
    v = 35 / v;
}
catch(...)
{
    throw 2;
}

Сбой не доходит до catch, программа завершается с ошибкой.
Если же я внутрь try поставлю throw 1; - то сбой возникнет, но он будет обработан notify.

Как быть, чтобы:
1) Обрабатывались исключения, не только вызванные throw
2) Исключения обрабатывались сначала внутри локальных try catch блоков, а необработанные доходили до notify().
Это возможно?

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

2
Evgenii Legotckoi
  • 20 августа 2019 г. 13:17

Добрый день.

Вы делаете некорректную попытку создать исключение.

Исключения генерируются кодом, то есть любое исключение, которое вы перехватываете, всегда генерируется оператором throw.

Деление на ноль не генерирует исключение в общем случае, оно просто кладёт программу.

То есть даже такой код не сгенерирует ожидаемое вами исключение

#include <iostream>

using namespace std;

int main()
{
    try
    {
        cout << "try 1" << endl;
        int v = 0;
        v = 35 / v;
        cout << "try 2" << endl;
    }
    catch(...)
    {
        cout << "try 3" << endl;
    }
    return 0;
}

Так что, предполагаю, что по первому пункту у вас в данный момент проблема надуманная.

Впрочем на некоторых форумах пишут, что данные исключения замаскированные сопроцессором и их можно ловить. Например, вот это должно работать под Windows.

// compile with: /EHa
#include <stdio.h>
#include <windows.h>
#include <eh.h>

void SEFunc();
void trans_func( unsigned int, EXCEPTION_POINTERS* );

int main( void )
{
    try
    {
        _set_se_translator( trans_func );
        SEFunc();
    }
    catch( const std::exception& e )
    {
        printf( " caught exception - %s.\n",e.what() );
    }
}
void SEFunc()
{
    int x, y=0;
    x = 5 / y;
}

void trans_func( unsigned int u, EXCEPTION_POINTERS* pExp)
{
    printf( "Some structured exception occurred.\n" );
    throw std::exception("may be division by zero - for more details look at my 'pExp'");
}

Но это уже платформозависимый код.

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

    grig_p
    • 21 августа 2019 г. 1:31

    Спасибо большое.
    Я долгое время писал на Object Pascal, привык, что там любое исключение, а не только сгенерированное самостоятельно, может быть перехвачено и обработано в блоках try. Дело в том, что не всегда можно точно предугадать, какой код приведет к сбою. И когда программа просто "падает", не оставляя следов, такое отладить сложно, особенно если оно нестабильно. Для этого и хотел сделать логирование сбоев, как это делал в Object Pascal.

      Комментарии

      Только авторизованные пользователи могут публиковать комментарии.
      Пожалуйста, авторизуйтесь или зарегистрируйтесь
      AD

      C++ - Тест 004. Указатели, Массивы и Циклы

      • Результат:50баллов,
      • Очки рейтинга-4
      m
      • molni99
      • 26 октября 2024 г. 11:37

      C++ - Тест 004. Указатели, Массивы и Циклы

      • Результат:80баллов,
      • Очки рейтинга4
      m
      • molni99
      • 26 октября 2024 г. 11:29

      C++ - Тест 004. Указатели, Массивы и Циклы

      • Результат:20баллов,
      • Очки рейтинга-10
      Последние комментарии
      i
      innorwall15 ноября 2024 г. 13:27
      Релиз утилиты развертывания С++/Qt и QML приложений CQtDeployer v1.4.0 (Binary Box) optionally substituted alkoxy, optionally substituted alkenyloxy, optionally substituted alkynyloxy, optionally substituted aryloxy, OCH, OC H, OC H, OC H, OC H, OC H, OC H, O C CH, OCH CH OH, O…
      i
      innorwall15 ноября 2024 г. 8:26
      Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
      i
      innorwall15 ноября 2024 г. 6:03
      Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
      i
      innorwall14 ноября 2024 г. 22:42
      Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
      Сейчас обсуждают на форуме
      i
      innorwall14 ноября 2024 г. 14:39
      добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
      i
      innorwall11 ноября 2024 г. 21:55
      Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
      9
      9Anonim25 октября 2024 г. 19:10
      Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
      ИМ
      Игорь Максимов3 октября 2024 г. 14:05
      Реализация навигации по разделам Спасибо Евгений!

      Следите за нами в социальных сетях