我知道这不是关于取消BackGroundWorker的第一个问题,但我找不到解决问题的答案。
我有一个发送文件的方法..我使用backgroundworker来调用它。
那么我怎样才能在发送文件的过程中取消backgroundworker ..我的意思是我应该把它放在哪里
if (backgroundWorker1.CancellationPending == true)
{
e.Cancel = true;
break;
}
这是代码:
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
List<object> job = (List<object>)e.Argument;
string srcPath = (string)job[0];
string destPath = (string)job[1];
SendFile(srcPath, destPath);
}
发送方式:
private void SendFile(string srcPath, string destPath)
{
string dest = Path.Combine(destPath, Path.GetFileName(srcPath));
using (fs = new FileStream(srcPath, FileMode.Open, FileAccess.Read))
{
try
{
long fileSize = fs.Length;
if (sizeAll == 0)
sizeAll = fileSize;
sum = 0;
int count = 0;
data = new byte[packetSize];
SendCommand("receive<" + dest + "<" + fs.Length.ToString());
ProgressLabel(++fileCount, allFileCount);
InfoLabel("Sending " + srcPath, "busy");
while (sum < fileSize)
{
count = fs.Read(data, 0, data.Length);
network.Write(data, 0, count);
sum += count;
sumAll += count;
backgroundWorker1.ReportProgress((int)((sum * 100) / fileSize));
}
network.Flush();
}
finally
{
network.Read(new byte[1], 0, 1);
CloseTransfer();
}
}
}
我应该在send方法中检查while()循环中的CancellationPending ..但是我无法从这个方法到[背景工作者] [e.Cancel] ..我该怎么办?
答案 0 :(得分:8)
DoWorkEventArgs e可以作为SendFile中的第三个参数传递:
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
List<object> job = (List<object>)e.Argument;
string srcPath = (string)job[0];
string destPath = (string)job[1];
SendFile(srcPath, destPath, e);
}
然后SendFile将
private void SendFile(string srcPath, string destPath, DoWorkEventArgs e)
并在你的循环中,在ReportProgress之后
if (backgroundWorker1.CancellationPending == true)
{
e.Cancel = true;
return; // this will fall to the finally and close everything
}
答案 1 :(得分:3)
将它放在while
循环中:
while (sum < fileSize)
{
if (worker.CancellationPending)
{
e.Cancel = true;
break;
}
count = fs.Read(data, 0, data.Length);
network.Write(data, 0, count);
sum += count;
sumAll += count;
backgroundWorker1.ReportProgress((int)((sum * 100) / fileSize));
}
network.Flush();