Namespaces
Variants

std:: bad_exception

From cppreference.net
Utilities library
Определено в заголовке <exception>
class bad_exception : public exception

std::bad_exception - это тип исключения, выбрасываемого средой выполнения C++ в следующих ситуациях:

  • Если std::exception_ptr сохраняет копию перехваченного исключения и если конструктор копирования объекта исключения, перехваченного std::current_exception выбрасывает исключение, то захваченное исключение является экземпляром std::bad_exception .
(начиная с C++11)
  • Если динамическая спецификация исключений нарушена и std::unexpected выбрасывает или повторно выбрасывает исключение, которое всё ещё нарушает спецификацию исключений, но спецификация исключений допускает std::bad_exception , то выбрасывается std::bad_exception .
(до C++17)
cpp/error/exception std-bad exception-inheritance.svg

Диаграмма наследования

Все функции-члены std::bad_exception являются constexpr .

(начиная с C++26)

Содержание

Функции-члены

создает объект bad_exception
(public member function)
копирует объект
(public member function)
[virtual]
возвращает пояснительную строку
(virtual public member function)

Унаследовано от std:: exception

Функции-члены

[virtual]
уничтожает объект исключения
(виртуальная публичная функция-член std::exception )
[virtual]
возвращает поясняющую строку
(виртуальная публичная функция-член std::exception )

Примечания

Макрос тестирования возможностей Значение Стандарт Функция
__cpp_lib_constexpr_exceptions 202411L (C++26) constexpr для типов исключений

Пример

Компилируется только в режимах C++14 или более ранних (может выдавать предупреждения).

#include <exception>
#include <iostream>
#include <stdexcept>
void my_unexp()
{
    throw;
}
void test()
    throw(std::bad_exception) // Dynamic exception specifications
                              // are deprecated in C++11
{
    throw std::runtime_error("test");
}
int main()
{
    std::set_unexpected(my_unexp); // Deprecated in C++11, removed in C++17
    try
    {
        test();
    }
    catch (const std::bad_exception& e)
    {
        std::cerr << "Caught " << e.what() << '\n';
    }
}

Возможный вывод:

Caught std::bad_exception