Пространства имён
Варианты
Действия

std::bad_typeid

Материал из cppreference.com
< cpp‎ | types
 
 
Библиотека метапрограммирования
Свойства типов
Категории типов
(C++11)
(C++14)  
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Свойства типов
(C++11)
(C++11)
(C++14)
(C++11)
(C++11)(до C++20*)
(C++11)(устарело в C++20)
(C++11)
Константы свойств типа
Метафункции
(C++17)
Поддерживаемые операции
Запросы отношений и свойств
Модификации типов
Преобразования типов
(C++11)(устарело в C++23)
(C++11)(устарело в C++23)
(C++11)
(C++11)
(C++17)

(C++11)(до C++20*)(C++17)
Рациональная арифметика времени компиляции
Целочисленные последовательности времени компиляции
 
Определено в заголовочном файле <typeinfo>
class bad_typeid :publicstd::exception;

Исключение этого типа возникает, когда оператор typeid применяется к разыменованному значению нулевого указателя полиморфного типа.

cpp/error/exceptionstd-bad typeid-inheritance.svg

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

Содержание

[править]Функции-элементы

(конструктор)
создаёт новый объект bad_typeid
(public функция-элемент)
operator=
заменяет объект bad_typeid
(public функция-элемент)
what
возвращает пояснительную строку
(public функция-элемент)

std::bad_typeid::bad_typeid

(1)
bad_typeid()throw();
(до C++11)
bad_typeid()noexcept;
(начиная с C++11)
(2)
bad_typeid(const bad_typeid& other )throw();
(до C++11)
bad_typeid(const bad_typeid& other )noexcept;
(начиная с C++11)

Создаёт новый объект bad_typeid с определённой реализацией строкой байтов, заканчивающейся нулём, которая доступна через what().

1) Конструктор по умолчанию.
2) Конструктор копирования. Если *this и other имеют динамический тип std::bad_typeid , тогда std::strcmp(what(), other.what())==0.(начиная с C++11)

Параметры

other другой объект исключения для копирования

std::bad_typeid::operator=

bad_typeid& operator=(const bad_typeid& other )throw();
(до C++11)
bad_typeid& operator=(const bad_typeid& other )noexcept;
(начиная с C++11)

Присваивает содержимое содержимому other. Если *this и other имеют динамический тип std::bad_typeid, тогда std::strcmp(what(), other.what())==0 после присваивания.(начиная с C++11)

Параметры

other другой объект исключения для присваивания

Возвращаемое значение

*this

std::bad_typeid::what

virtualconstchar* what()constthrow();
(до C++11)
virtualconstchar* what()constnoexcept;
(начиная с C++11)

Возвращает пояснительную строку.

Параметры

(нет)

Возвращаемое значение

Указатель на завершающуюся нулём строку с пояснительной информацией. Строка подходит для преобразования и отображения в виде std::wstring. Указатель гарантированно действителен, по крайней мере, до тех пор, пока объект исключения, из которого он получен, не будет уничтожен или пока не будет вызвана неконстантная функция-элемент (например, оператор присваивания копированием) для объекта исключения.

Примечание

Реализации могут, но не обязаны переопределять what().

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

Функции-элементы

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

[править]Пример

#include <iostream>#include <typeinfo>   struct S {// Тип должен быть полиморфнымvirtualvoid f();};   int main(){ S* p = nullptr;try{std::cout<<typeid(*p).name()<<'\n';}catch(const std::bad_typeid& e){std::cout<< e.what()<<'\n';}}

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

Attempted a typeid of NULL pointer!
close