gpt4 book ai didi

c# - 使用 backgroundworker 手动停止调试

转载 作者:行者123 更新时间:2023-11-30 12:15:37 27 4
gpt4 key购买 nike

我正在使用 BackgroundWorker(带有进度条的弹出窗口)编写 WPF C# 项目。

我开始调试(F5 键)以检查我的程序。 BackgroundWorker 完成并关闭弹出窗口后,关闭 MainWindow 不会自动停止调试过程。我必须手动点击 Shift+F5 来停止调试。

我认为 BackgroundWorker 应该自动处理线程。但无论如何,我仍然在 RunWorkerCompleted 方法中调用了 backgroundworker.Dispose()backgroundworker.CancelAsync() 。然而,在关闭弹出窗口和完成 BackgroundWorker 时,我仍然必须手动执行 Shift+F5 以停止调试。

后台发生了什么,避免程序自动停止调试?我怎样才能知道?

注意:我已确保后台工作人员已完成 DoWork 并在我关闭它之前完成。使用弹出窗口和 BackgroundWorker,它会在我关闭主窗口时自动停止调试。

[使用代码编辑]

public partial class MainWindow : Window
{
BackgroundWorker backgroundworker1 = new BackgroundWorker();

PopUp pop1 = new PopUp();

public MainWindow()
{
InitializeComponent();

backgroundworker1.DoWork += BackgroundWorker_DoWork;
backgroundworker1.RunWorkerCompleted += BackgroundWorker_RunWorkerCompleted;
backgroundworker1.WorkerReportsProgress = true;
backgroundworker1.ProgressChanged += BackgroundWorker_ProgressChanged;
backgroundworker1.WorkerSupportsCancellation = true;
}

private void startBtn_Click(object sender, RoutedEventArgs e)
{
pop1 = new PopUp();

int iteration = 0;
if (int.TryParse(iterationTb1.Text, out iteration))
{
pop1.Show();
backgroundworker1.Dispose();
backgroundworker1.RunWorkerAsync(iteration);
outputTb1.Text = "running...";
}
}

private void cancelBtn_Click(object sender, RoutedEventArgs e)
{
pop1.Close();
backgroundworker1.CancelAsync();
}

public static int DoSlowProcess(int iterations, BackgroundWorker worker, DoWorkEventArgs e)
{
int result = 0;

for (int i = 0; i <= iterations; i++)
{
if (worker != null)
{
if (worker.CancellationPending)
{
e.Cancel = true;
return result;
}
if (worker.WorkerReportsProgress)
{
int percentComplete = (int)((float)i / (float)iterations * 100);
worker.ReportProgress(percentComplete);
}
}

Thread.Sleep(100);
result = i;
}

return result;
}


private void BackgroundWorker_DoWork(object sender, DoWorkEventArgs e)
{
var bgw = sender as BackgroundWorker;
e.Result = DoSlowProcess((int)e.Argument, bgw, e);
}

private void BackgroundWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (e.Error != null)
{
MessageBox.Show(e.Error.Message);
}
else if (e.Cancelled)
{
outputTb1.Text = "Canceled";
}
else
{
outputTb1.Text = e.Result.ToString();
backgroundworker1.CancelAsync();
backgroundworker1.Dispose();
pop1.Close();
pop1.progressBar1.Value = 0;
}
}

private void BackgroundWorker_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
pop1.progressBar1.Value = e.ProgressPercentage;
pop1.progressLb1.Content = e.ProgressPercentage.ToString();
}
}

最佳答案

好的,我可以重现您的问题并找到原因。

改变这一行:

// PopUp pop1 = new PopUp();  <-- this never-used Win was blocking your close-down.
PopUp pop1 = null;

因为你也有

pop1 = new PopUp();
int iteration = 0;

创建对象只是为了初始化一个 var,然后再覆盖它始终是一种反模式。在这种情况下,它实际上是有害的,因为您创建了一个 Window 但从未 Show() 或 Close() 它。

请注意,不涉及后台工作人员。不可能,它使用 ThreadPool,这意味着后台线程。您可以关闭一个有多个 Backgroundworker 运行而没有问题的应用程序。

关于c# - 使用 backgroundworker 手动停止调试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7056584/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com