例外をスローし、Application.ThreadException
イベント ハンドラーで例外をキャッチするときに、奇妙な動作が見られます。
基本的に、以下のサンプルで起こっていることは、 のDoWork
イベント ハンドラーで例外がスローされることBackgroundWorker
です。RunWorkerCompleted
イベント ハンドラーは、元の例外を内部例外として、新しい例外を再スローします。
内部例外がThreadException
イベント ハンドラーに表示され、実際の例外がスローされないのはなぜですか? RunWorkerCompleted
イベント ハンドラーで内部例外を提供しない場合、正しい例外が表示されます。
using System;
using System.Windows.Forms;
using System.ComponentModel;
namespace WierdExceptionApp
{
class WierdExceptionForm : Form
{
BackgroundWorker worker = new BackgroundWorker();
public WierdExceptionForm()
{
worker.DoWork += new DoWorkEventHandler(worker_DoWork);
worker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(worker_RunWorkerCompleted);
worker.RunWorkerAsync();
}
void worker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (e.Error != null)
{
throw new Exception("worker_RunWorkerCompleted", e.Error);
}
}
void worker_DoWork(object sender, DoWorkEventArgs e)
{
throw new Exception("worker_DoWork");
}
[STAThread]
static void Main()
{
Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException);
Application.Run(new WierdExceptionForm());
}
static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e)
{
MessageBox.Show(e.Exception.Message);
}
}
}