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()