Compartilhar via


Como definir e instalar um identificador de exceção global

O exemplo de código a seguir demonstra como exceções sem tratamento podem ser capturadas. O formulário de exemplo contém um botão que, quando pressionado, executa uma referência nula, fazendo com que uma exceção seja lançada. Essa funcionalidade representa uma falha de código típica. A exceção resultante é capturada pelo manipulador de exceção em todo o aplicativo instalado pela função principal.

Isso é feito associando um delegado ao evento ThreadException. Nesse caso, exceções subsequentes são enviadas para o método App::OnUnhandled.

Exemplo

// global_exception_handler.cpp
// compile with: /clr
#using <system.dll>
#using <system.drawing.dll>
#using <system.windows.forms.dll>

using namespace System;
using namespace System::Threading;
using namespace System::Drawing;
using namespace System::Windows::Forms;

ref class MyForm : public Form
{
   Button^ b;
public:
   MyForm( )
   {
      b = gcnew Button( );
      b->Text = "Do Null Access";
      b->Size = Drawing::Size(150, 30);
      b->Click += gcnew EventHandler(this, &MyForm::OnClick);
      Controls->Add(b);
   }
   void OnClick(Object^ sender, EventArgs^ args)
   {
      // do something illegal, like call through a null pointer...
      Object^ o = nullptr;
      o->ToString( );
   }
};

ref class App
{
public:
   static void OnUnhandled(Object^ sender, ThreadExceptionEventArgs^ e)
   {
      MessageBox::Show(e->Exception->Message, "Global Exeception");
      Application::ExitThread( );
   }
};

int main()
{
   Application::ThreadException += gcnew
      ThreadExceptionEventHandler(App::OnUnhandled);

   MyForm^ form = gcnew MyForm( );
   Application::Run(form);
}

Confira também

Tratamento de exceção