Este artículo se tradujo automáticamente. Para ver el artículo en inglés, active la casilla Inglés. Además, puede mostrar el texto en inglés en una ventana emergente si mueve el puntero del mouse sobre el texto.
Traducción
Inglés

Clase ThreadExceptionEventArgs

 

Publicado: octubre de 2016

Proporciona datos para el evento ThreadException.

Espacio de nombres:   System.Threading
Ensamblado:  System (en System.dll)


public class ThreadExceptionEventArgs : EventArgs

NombreDescripción
System_CAPS_pubmethodThreadExceptionEventArgs(Exception)

Inicializa una nueva instancia de la clase ThreadExceptionEventArgs.

NombreDescripción
System_CAPS_pubpropertyException

Obtiene el Exception que se ha producido.

NombreDescripción
System_CAPS_pubmethodEquals(Object)

Determina si el objeto especificado es igual al objeto actual.(Heredado de Object).

System_CAPS_protmethodFinalize()

Permite que un objeto intente liberar recursos y realizar otras operaciones de limpieza antes de que sea reclamado por la recolección de elementos no utilizados.(Heredado de Object).

System_CAPS_pubmethodGetHashCode()

Sirve como la función hash predeterminada.(Heredado de Object).

System_CAPS_pubmethodGetType()

Obtiene el Type de la instancia actual.(Heredado de Object).

System_CAPS_protmethodMemberwiseClone()

Crea una copia superficial del Object actual.(Heredado de Object).

System_CAPS_pubmethodToString()

Devuelve una cadena que representa el objeto actual.(Heredado de Object).

Un ThreadExceptionEventArgs se crea un subproceso cuando se produce una excepción no controlada. ThreadExceptionEventArgs contiene el Exception que se ha producido.

En el siguiente ejemplo permite provocar un ThreadException evento haciendo clic en button1 en un formulario. En el ejemplo se crea dos clases. La ErrorHandler clase crea el formulario y el botón que provoca el evento. La CustomExceptionHandler clase proporciona los métodos para controlar la excepción.

En Main en el ErrorHandler (clase), el código crea una nueva instancia de la clase, es decir, de control de excepciones una instancia de la CustomExceptionHandler. A continuación, la instancia se agrega al evento y se ejecuta la aplicación.

En el OnThreadException método en el CustomExceptionHandler (clase), el ejemplo utiliza un try...catch...finally instrucción para procesar la excepción. El ShowThreadExceptionDialog método crea el mensaje para mostrar y se muestra en un cuadro de mensaje.

using System;
using System.Threading;
using System.Windows.Forms;

// Create a form with a button that, when clicked, throws an exception.
 public class ErrorForm : System.Windows.Forms.Form
 {
    internal Button button1;

    public ErrorForm() : base()
    {
       // Add the button to the form.
       this.button1 = new System.Windows.Forms.Button();
       this.SuspendLayout();
       this.button1.Location = new System.Drawing.Point(100, 43);
       this.button1.Size = new System.Drawing.Size(75, 23);
       this.button1.Text = "Click!";
       this.Controls.Add(this.button1);
       this.button1.Click += new EventHandler(this.button1_Click);

       this.Text = "ThreadException";
       this.ResumeLayout(false);
    }

    // Throw an exception when the button is clicked.
    private void button1_Click(object sender, System.EventArgs e)
    {
       throw new ArgumentException("The parameter was invalid");
    }

    public static void Main()
    {
       // Add the event handler.
       Application.ThreadException += new ThreadExceptionEventHandler(CustomExceptionHandler.OnThreadException);

       // Start the example.
       Application.Run(new ErrorForm());
    }
 }

 // Create a class to handle the exception event.
 internal class CustomExceptionHandler
 {
     // Handle the exception event
    public static void OnThreadException(object sender, ThreadExceptionEventArgs t)
    {
       DialogResult result = ShowThreadExceptionDialog(t.Exception);

       // Exit the program when the user clicks Abort.
       if (result == DialogResult.Abort) 
          Application.Exit();
    }

    // Create and display the error message.
    private static DialogResult ShowThreadExceptionDialog(Exception e)
    {
       string errorMsg = "An error occurred.  Please contact the adminstrator " +
            "with the following information:\n\n";
       errorMsg += String.Format("Exception Type: {0}\n\n", e.GetType().Name);
       errorMsg += "\n\nStack Trace:\n" + e.StackTrace;
       return MessageBox.Show(errorMsg, "Application Error", 
            MessageBoxButtons.AbortRetryIgnore, MessageBoxIcon.Stop);
    }
 }

.NET Framework
Disponible desde 1.1

Cualquier miembro ( Compartido en Visual Basic) estático público de este tipo es seguro para subprocesos. No se garantiza que los miembros de instancia sean seguros para subprocesos.

Volver al principio
Mostrar: