你们其中一个人是否知道如何在应用程序的主线程中捕获特定线程中抛出的异常?
例如,我有一个非常简单的线程做一些基本的东西:
try
{
Thread t = new Thread(new ThreadStart(Cache.initialize));
t.Start();
t.Name = "loading";
while (t.IsAlive)
{
progressBar1.PerformStep();
}
}
catch (PropertyOrFieldNotInitializedException ex)
{
Console.WriteLine(ex.StackTrace);
MessageBox.Show("L'application ne peut se connecter au serveur, vérifiez votre connexion");
}
问题是这个catch是没用的,因为在主栈中不会检索异常..
public static void initialize()
{
try
{
ctxMdv = new ClientContext(Configuration.getInstance().UrlMdv);
...
}
catch (PropertyOrFieldNotInitializedException e) //si le serveur n'est pas démarré
{
throw ;
}
这里所有东西都停在“throw”处并且没有任何处理,即使在主堆栈中我试图抓住它显示一个消息框。 那我怎么能抓住我的线程中引发的PropertyOrFieldNotInitializedException呢? 您是否有一些最佳实践来从c#中的线程中捕获异常?
非常感谢!
PS:好的,谢谢Thorsten Dittmar给出的答案,我可以这样做: 这是主线程 BackgroundWorker bw = new BackgroundWorker();
bw.WorkerReportsProgress = true;
bw.DoWork += new DoWorkEventHandler(bw_DoWork);
bw.ProgressChanged += new ProgressChangedEventHandler(bw_ProgressChanged);
bw.RunWorkerCompleted += new RunWorkerCompletedEventHandler(bw_RunWorkerCompleted);
bw.RunWorkerAsync();
这是我的笨蛋:
private void bw_DoWork(object sender, DoWorkEventArgs e)
{
Cache.initialize(); // the thread job
}
这里是mi完成事件,即使引发异常也会发生:
private void bw_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (!(e.Error == null))
if (e.Error is WebException)
Console.WriteLine(e.Error.StackTrace);
MessageBox.Show("L'application ne peut se connecter au serveur, vérifiez votre connexion");
this.Dispose();
Application.Exit();
}
我计划处理ProgressChanged代表以纠正进度条...;) 谢谢!
答案 0 :(得分:4)
嗯,一种方法是在您的情况下使用BackgroundWorker
而不是线程。您不需要try
块,因为错误将自动捕获并传递给您在工作人员结束时分配的处理程序。
编辑:
您还可以使用BackgroundWorker
的活动向表单报告进度,以便正确更新进度条; - )
答案 1 :(得分:1)