C# 后台工作人员已完成事件在实际完成工作之前触发
在我的应用程序中,当用户单击菜单项时,系统会提示他们选择一个文件,然后我使用后台工作程序加载和解析该文件,并在此操作期间将进度报告给进度条。工作完成后,我启动一个新窗口,将解析后的数据传递给该窗口。由于某些原因,在解析数据并传递空参数(而不是数据)之前,会打开新窗口 我的点击事件:C# 后台工作人员已完成事件在实际完成工作之前触发,c#,events,backgroundworker,C#,Events,Backgroundworker,在我的应用程序中,当用户单击菜单项时,系统会提示他们选择一个文件,然后我使用后台工作程序加载和解析该文件,并在此操作期间将进度报告给进度条。工作完成后,我启动一个新窗口,将解析后的数据传递给该窗口。由于某些原因,在解析数据并传递空参数(而不是数据)之前,会打开新窗口 我的点击事件: private void CIRCUIT_INSTALATION_SCHEDULED_Click(object sender, RoutedEventArgs e) { //prevents users fr
private void CIRCUIT_INSTALATION_SCHEDULED_Click(object sender, RoutedEventArgs e)
{
//prevents users from selecting other menu items
disableAll();
System.Windows.Forms.OpenFileDialog mainExcelFileDialog = new System.Windows.Forms.OpenFileDialog();
mainExcelFileDialog.InitialDirectory = System.Configuration.ConfigurationManager.AppSettings["MainWorkbookDirectory"];
mainExcelFileDialog.Title = "Main Excel File";
mainExcelFileDialog.ShowDialog();
string mainPath = mainExcelFileDialog.FileName;
this.Cursor = System.Windows.Input.Cursors.Wait;
BackgroundWorker cisWorker = new BackgroundWorker();
cisWorker.DoWork += cisWorker_DoWork;
cisWorker.ProgressChanged+=cisWorker_ProgressChanged;
cisWorker.RunWorkerCompleted += cisWorker_RunWorkerCompleted;
cisWorker.RunWorkerAsync(mainPath);
}
我的工作是:
void cisWorker_DoWork(object sender, DoWorkEventArgs e)
{
BackgroundWorker worker = sender as BackgroundWorker;
using (FileStream fs = new FileStream(e.Argument.ToString() , FileMode.Open))
{
//copy filestream to memorystream chunk by chunk, reporting progress.
using (MemoryStream ms = new MemoryStream())
{
byte[] buffer = new byte[32768];
int read;
int steps = Convert.ToInt32(fs.Length / buffer.Length);
int i = 0;
while ((read = fs.Read(buffer, 0, buffer.Length)) > 0)
{
ms.Write(buffer, 0, read);
i++;
var progress = new Decimal(i) / new Decimal(steps);
var outOf = Math.Round(progress * 50);
worker.ReportProgress(Convert.ToInt32(outOf));
}
worker.ReportProgress(50);
ms.Position = 0;
//load excel workbook dataset from memorystream
using (var xlr = Excel.ExcelReaderFactory.CreateOpenXmlReader(ms))
{
xlr.IsFirstRowAsColumnNames = true;
mainWorkbook = xlr.AsDataSet();
worker.ReportProgress(100);
}
}
}
}
我的发言全文如下:
void cisWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
this.Cursor = System.Windows.Input.Cursors.Arrow;
CircuitInstallationScheduledWindow CIS_Window = new CircuitInstallationScheduledWindow();
CIS_Window.Show();
CIS_Window.Closed += CIS_Window_Closed;
}
编辑:
我将mainPath参数添加到cisWorker.runWorkerAsync()方法中。不幸的是,问题仍然存在。是正确的。我收到一个错误,因为我没有设置cisWorker.WorkerReportsProgress=true代码>我仍然不知道为什么错误没有破坏调试器,因为它没有被处理,但是我在我完成的方法中做了一个print语句,这帮助我找到了罪魁祸首
void cisWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
Console.WriteLine(e.Error);
this.Cursor = System.Windows.Input.Cursors.Arrow;
CircuitInstallationScheduledWindow CIS_Window = new CircuitInstallationScheduledWindow(mainWorkbook, abfsDatabase);
CIS_Window.Show();
CIS_Window.Closed += CIS_Window_Closed;
}
基本上,您应该检查您的数据是否不为空,即在工作期间没有发生错误
void cisWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (e.Error == null)
{
/* Your mainWorkbook shouldn't be null */
this.Cursor = System.Windows.Input.Cursors.Arrow;
CircuitInstallationScheduledWindow CIS_Window = new CircuitInstallationScheduledWindow();
CIS_Window.Show();
CIS_Window.Closed += CIS_Window_Closed;
}
else
{
// Handle error
}
}
根据提供的代码,我看不到您向CIS_窗口传递任何数据。也许这就是为什么它是空的?如果没有,请说明数据是如何传递的。您在DoWork中遇到异常,而在Completed中忽略它。有关规范已完成事件的信息,请参阅。不,您是对的。我一直在修改我的代码,试图修复这个问题,上次我一定忘了传入mainPath参数。虽然我改了,但还是开始得太快了。我将编辑问题。如果我在DoWork中遇到异常,为什么不抛出它?我没有任何尝试/收获。我如何知道异常是什么,以便处理它?旁注…您应该检查mainExcelFileDialog.ShowDialog()的结果代码>用于正常
。如果用户点击Cancel,您将处理什么文件名?…并且您的UI将被禁用,因为您已经调用了disableAll()代码>!