Я пишу проект WPF С# с использованием BackgroundWorker
(всплывающее окно с индикатором выполнения).
Я запускаю отладку (клавиша F5), чтобы проверить свою программу. После завершения BackgroundWorker
и закрытия всплывающего окна закрытие MainWindow
не останавливает автоматически процесс отладки. Мне приходится вручную нажимать Shift+F5, чтобы остановить отладку.
Я думал, что BackgroundWorker
должен был позаботиться о теме автоматически. Но в любом случае я все еще вызываю backgroundworker.Dispose()
и backgroundworker.CancelAsync()
в методе RunWorkerCompleted
. И тем не менее, после закрытия всплывающего окна и завершения BackgroundWorker
мне все еще приходится вручную нажимать Shift+F5, чтобы остановить отладку.
Что происходит в фоновом режиме, чтобы программа не останавливала отладку автоматически? Как я могу узнать?
ПРИМЕЧАНИЕ. Я удостоверился, что фоновый рабочий процесс завершен, прежде чем я его закрою. Со всплывающим окном и 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();
}
}
ShutdownMode
вApp
? Если да, то к чему? - person svick   schedule 14.08.2011