bad_typeid (Excepción)

 

Para obtener la documentación más reciente de Visual Studio 2017 RC, consulte Documentación de Visual Studio 2017 RC.

La excepción bad_typeid la produce el operador typeid cuando el operando de typeid es un puntero NULL.

  
      catch (bad_typeid)  
   statement  

La interfaz de bad_typeid es:

class bad_typeid : public exception  
{  
public:  
   bad_typeid(const char * _Message = "bad typeid");  
   bad_typeid(const bad_typeid &);  
   virtual ~bad_typeid();  
};  

En el ejemplo siguiente se muestra el operador typeid que produce una excepción bad_typeid.

// expre_bad_typeid.cpp  
// compile with: /EHsc /GR  
#include <typeinfo.h>  
#include <iostream>  
  
class A{  
public:  
   // object for class needs vtable  
   // for RTTI  
   virtual ~A();  
};  
  
using namespace std;  
int main() {  
A* a = NULL;  
  
try {  
   cout << typeid(*a).name() << endl;  // Error condition  
   }  
catch (bad_typeid){  
   cout << "Object is NULL" << endl;  
   }  
}  

Object is NULL  

Información de tipos en tiempo de ejecución
Palabras clave de C++

Mostrar: