我正在使用ThreadPool从服务器下载多个文件。我有一个要下载的文件列表,其中一些文件很大。我想下载其他小型文件后下载这些巨大的文件。而且,我正在使用WebClient.DownloadFile()
。
目前我正在使用Thread.Join(time)
启动大量文件的线程,以便在一段时间后启动。但是不能保证其他下载在那时就完成了。 time
的值将根据网络速度而变化。
有没有更好的解决方案来处理这个问题?请帮忙。
答案 0 :(得分:0)
使用ManualResetEvent对象并在进程内设置它并等待所有重置事件。像这样:
public void DispatchWork(IEnumerable<string> worklist)
{
var resetEvents = new List<ManualResetEvent>();
var batch = 100;
foreach (work in worklist)
{
var resetEvent = new ManualResetEvent(false);
resetEvents.Add(resetEvent);
ThreadPool.QueueUserWorkItem((a) =>
{
try
{
// do work
}
catch (Exception e)
{
// do something
throw;
}
finally
{
if (resetEvent != null) resetEvent.Set();
}
});
}
foreach (var resetEvent in resetEvents)
{
resetEvent.WaitOne();
resetEvent.Dispose(); // todo: use try-finally
}
resetEvents.Clear();
}