Почему не вызывается функция неожиданная?

Я ожидаю, что следующий код вызовет мой неожиданный обработчик, но мой прекратить вместо этого вызывается обработчик:

#include <except>
#include <iostream>

void my_terminate() {
std::cerr << "my terminate handler";
std::exit(0);
}

void my_unexpected() {
std::cerr << "my unexpected handler";
std::exit(EXIT_FAILURE);
}

#pragma argsused
int main(int argc, char* argv[])
{
std::set_terminate(my_terminate);
std::set_unexpected(my_unexpected);
try {
throw std::exception();
} catch (const std::logic_error&) {
}
return 0;
}

Руководство разработчика C ++ Builder 6 явно рекомендует устанавливать пользовательские неожиданные обработчики через set_unexpected(), Что я делаю не так, или это просто ошибка в C ++ — Builder 6?

3

Решение

Обработчик, установленный вызовом std::set_unexpected (за std::unexpected) будет вызываться при возникновении непредвиденного исключения; не когда исключение не обработано. Неожиданный обработчик вызывается, когда нарушена спецификация динамического исключения.

В качестве примера;

void my_terminate() {
std::cerr << "my terminate handler";
std::exit(0);
}

void my_unexpected() {
std::cerr << "my unexpected handler";
std::exit(EXIT_FAILURE);
}

void function() throw() // no exception in this example, but it could be another spec
{
throw std::exception();
}

int main(int argc, char* argv[])
{
std::set_terminate(my_terminate);
std::set_unexpected(my_unexpected);
try {
function();
} catch (const std::logic_error&) {
}
return 0;
}

Выход

мой неожиданный обработчик

Обработчик, установленный std::set_terminate называется std::terminate (по многочисленным причинам, указанным в ссылке). Интересно, что поведение по умолчанию при исключение выбрасывается, но не пойман, чтобы позвонить std::terminate.

10

Другие решения

Когда происходит необъяснимое исключение, terminate называется.

int main()
{
throw 1; // terminate
}

Когда происходит неожиданное исключение, unexpected называется.

void foo() throw(int)
{
throw "unexpected will be called.";
}

int main()
{
foo();
}

Я покажу вам пример программы, которая завершается / неожиданно:

#include <cstdlib>
#include <iostream>
#include <exception>

#define TEST_TERMINATE

void my_terminate()
{
std::cout << "terminate!" << std::endl;
std::abort();
}
void my_unexpected()
{
std::cout << "unexpected!" << std::endl;
std::abort();
}

void foo() throw(int)
{
throw "unexpected will be called.";
}

int main()
{
std::set_terminate(my_terminate);
std::set_unexpected(my_unexpected);

#ifdef TEST_TERMINATE
throw 1;
#else
foo();
#endif
}

(живой пример для прекратить, неожиданный)

2